部署网站到aws服务器

项目部署:网站部署到aws服务器(python)

  • 任意一个云服务器(阿里云,AWS,百度云,均可)
  • 一个已经完成的WEB项目

tips: 每个服务器的设置安全组不一样,可自行参考自己服务器如何设置

打开常用端口(高手可自行指定端口)

  • 80/80 Nginx的默认端口
  • 3306/3306 mysql的默认端口
  • 6379/6379 redis的默认端口
  • 23/23
  • 443/433
  • 22/22
  • 80/80
  • 3389/3389
`FLUSH PRIVILEGES;` 
[mysql] default-character-set=utf8 

tips:
使用虚拟环境,当项目多时,更方便维护和管理,这里以pipenv为例

  • pip3 install pipenv 安装虚拟环境
  • mkdir 你的文件夹 创建自己的文件夹

下载地址及安装方法,可以自行百度。都很简单

 rm -rf migrations/ python manage.py db init python manage.py db migrate python manage.py db upgrade 

介绍:
uwsgi是一个应用服务器,非静态文件的网络请求就必须通过他完成, 他也可以充当静态文件服务器,但不是他的
强项。uwsgi是使用python编写的,因此通过pip3 install uwsgi就可以了。(uwsgi必须安装在系统级别的Python环
境中,不要安装到虚拟环境中)。然后创建一个叫做uwsgi.ini的配置文件:

[uwsgi]   chdir = /root/flask-project/bbs/  wsgi-file = /root/flask-project/bbs/bbs.py  callable = app  home = /root/.local/share/virtualenvs/flask-project--bwy33Ao   master = true  processes = 10 http = :5000  chmod-socket = 666  vacuum = true 

退出虚拟环境 : deactivate或者exit

依赖环境安装
yum install -y gcc* pcre-devel openssl-devel

运行
uwsgi --ini uwsgi.ini

关闭uwsgi
pkill -f uwsgi -9

** 后台运行uwsgi **
uwsgi -d --ini uwsgi.ini

检查是否可行
在浏览器中访问http://ip地址:5000,如果能够访问
到页面(可能没有静态文件)说明uwsgi配置没有问题。

nginx介绍:
虽然uwsgi可以正常的部署我们的项目了。但我们还是依然要采用nginx来作为web服务器。使用nginx来作为web
服务器有以下好处:

1.安装:
yum install nginx

2.nginx的简单操作命名

  • 启动:systemctl start nginx
  • 关闭:systemctl stop nginx
  • 重启:systemctl restart nginx

3.添加配置文件
/etc/nginx/conf.d目录下,新建一个文件,叫做bbs.conf,然后将以下代码粘贴进去:

upstream bbs{ server 127.0.0.1:5000; }   listen 80;  server_name 47.xxx.xxx.30; charset utf-8;  client_max_body_size 75M;  location /static {  alias /root/flask-project/bbs/static; }  location / { uwsgi_pass 127.0.0.1:5000;  include /etc/nginx/uwsgi_params; } } 

写完配置文件后,为了测试配置文件是否设置成功,运行命令:service nginx configtest,如果不报错,说明成
功。 每次修改完了配置文件,都要记得运行systemctl start nginx。

在最后一行输入:
export PATH="$PATH:/需要添加的路径"

在执行
source /etc/profile

server {  listen 443 ssl;  server_name cloud.tencent.com;  ssl_certificate 1_cloud.tencent.com_bundle.crt;  ssl_certificate_key 2_cloud.tencent.com.key; ssl_session_timeout 5m;  ssl_protocols TLSv1 TLSv1.1 TLSv1.2;  ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE; ssl_prefer_server_ciphers on; location / {  root /var/www/cloud.tencent.com; index index.html index.htm; } } 

按如下配置nginx [在server下]

location / { proxy_pass http://127.0.0.1:5000; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $remote_addr; } 

python工程项目,用后台启动 输入log日志文件
nohup python -u app.py > ../nohup.log 2>&1 &

关闭后台python项目:
ps -ef | grep 文件名 查询进程号
kill -9 进程号 关闭该进程号的项目

确认本地安装了openssl
crt转pem:
openssl x509 -in 要转换的文件.crt -out 被转换成的命名.pem

加粗样式
openssl rsa -in 要转换的文件.key -out 被转成的文件命名.pem

原文链接:https://blog.csdn.net/weixin_45550881/article/details/106636147

© 版权声明
THE END
喜欢就支持一下吧
点赞10 分享