上篇我们完成了一个本地的Django项目,实现了博客列表和详情的功能。
利用Django开发博客网站并在阿里云上利用 Nginx + Gunicorn 部署上线(开发篇)_李威威wiwi的博客-CSDN博客本文我们将通过Django+Mysql实现一个简单的个人博客网站,同时在阿里云上通过Nginx 和gunicorn实现网站的线上部署运行。https://blog.csdn.net/agelee/article/details/127425833
本篇我们将利用Nginx和Gunicorn实现网站项目在阿里云上面实现Django项目的在线部署。
开发时我们用的是 Django 自带的开发服务器,但那个性能太差了,不可能用到线上环境。所以线上部署时,我们不仅要安装 Django,还要安装 Nginx 和 Gunicorn,这三兄弟的工作流程如下:
部署一个Django项目的步骤大概为如下:
本文采用阿里云,阿里云服务器可以试用一个月,我们以试用服务器为例来实现项目的部署。
在开通服务的界面,其他的可以随便填,操作系统我们采用Ubuntu 22.04 64位版本。
开通的时候我们选择仅操作系统,先不预装其他应用。
开通后进入管理实例界面,可以看到我们最关键的字段内容,公网IP:39.107.240.223
然后重置下我们的实例密码(否则登录服务器的时候默认会使用秘钥)
接着检查下我们的安全组内的入方向端口,至少需要80和22端口是打开的。
Xshell和Xftp都是 NetSarang 开发的远程工具。
下载地址如下,个人使用使用免费版就行了。
家庭/学校免费 - NetSarang Websitehttps://www.xshell.com/zh/free-for-home-school/
安装好软件之后,我们首先打开Xshell,新建一个会话,主机输入我们前面阿里云的公网地址。
选择用户身份验证,输入登录用户名和密码后点击连接按钮,完成登录。
Xftp和Xshell的安装和登录方式几乎一样,这里就不做特别介绍了。
安装软件之前,我们先升级下系统内库的版本,防止系统版本过旧导致问题。
~$ sudo apt-get update
~$ sudo apt-get upgrade
安装必要的软件:Nginx,Python,PIP,同时 PIP 安装了Python虚拟环境virtualenv
库。
~$ sudo apt-get install nginx
~$ sudo apt-get install python3
~$ sudo apt-get install python3-pip
~$ sudo pip3 install virtualenv
sudo apt install mysql-server
检查运行状态
sudo systemctl status mysql
安装完成后使用命令直接root用户登录
sudo mysql
(在MySQL 8.0上,root 用户默认通过auth_socket插件授权,无法使用密码登录,修改密码后才能启用密码登录。)
然后在mysql命令界面输入下面两条命令修改root用户的密码为你的最新密码:
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'newpassword';
mysql> FLUSH PRIVILEGES;
退出mysql:
mysql> exit
然后检查下使用root密码登录是否成功:
mysql -u root -p
如下界面代表登录成功。
顺手我们把数据库也一起创建了(名字和我们本地创建的一样就好了):
mysql> CREATE DATABASE IF NOT EXISTS django_blog DEFAULT CHARSET utf8;
部署项目到线上去的话,我们需要修改下配置文件django4blog/settings.py
。
DEBUG = False
ALLOWED_HOSTS = ['*']
# 静态文件收集目录
STATIC_ROOT = os.path.join(BASE_DIR, 'collected_static')
主要涉及3点:
接着我们需要修改下配置解决在线部署的跨域问题:
先PIP安装一下包django-cors-headers
:
pip install django-cors-headers
然后修改下配置文件django4blog/settings.py
INSTALLED_APPS = [
......
'corsheaders', #解决浏览器跨域问题
......
]
MIDDLEWARE = [
......
'corsheaders.middleware.CorsMiddleware', #解决浏览器跨域问题
'django.middleware.common.CommonMiddleware', #解决浏览器跨域问题
......
]
CORS_ORIGIN_ALLOW_ALL = True #解决浏览器跨域问题
CORS_ALLOW_CREDENTIALS = True #解决浏览器跨域问题
SECURE_CROSS_ORIGIN_OPENER_POLICY = 'None' #Django4 特定解决浏览器跨域问题
另外,如果我们服务器数据库密码和本地的数据库密码不一致,我们可以提前修改下配置文件的参数:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # 数据库引擎
'NAME': 'django_blog', # 数据库名称
'HOST': '127.0.0.1', # 数据库地址,本机 ip 地址 127.0.0.1
'PORT': 3306, # 端口
'USER': 'root', # 数据库用户名
'PASSWORD': 'newpassword', # 数据库密码 修改为服务器数据库密码
}
}
最后我们将我们本地项目需要用到的库列一个清单,以便在服务器上统一安装。
在本地虚拟环境中输入命令:pip freeze > requirements.txt
(env) E:\django_project\django4blog>pip freeze > requirements.txt
得到库清单文件requirements.txt
。
本地项目参数修订好之后,我们登陆Xftp,直接将本地项目文件夹django_project
复制到服务器
回到Xshell的服务器操作界面,进入我们的项目文件夹django_project
cd django_project
接着在服务器生成虚拟环境:
virtualenv --python=python3.10 myenv
进入虚拟环境:
source env/bin/activate
进入到django4blog
项目文件夹:
cd django4blog
输入如下命令安装项目必要的Python库。
(env) ../django4blog# pip3 install -r requirements.txt
如果在命令pip3 install -r requirements.txt
的时候出现如下错误。
是因为本地的tzdata库的版本太高,阿里的镜像版本目前只支持到2022.4,这时我们可以直接修改requirements.txt内的tzdata的版本为2022.4。
Ubuntu修改文件命令如下:
vi requirements.txt
,打开文件
按Insert或者i键,可以开始修改文件,将tzdata版本修改为2022.4
修改完成后,先按下Esc键,然后输入命令:wq
保存并退出文件。
重新执行命令
pip3 install -r requirements.txt
安装成功
接着分别输入如下命令完成静态资源收集和数据迁移。
(env) ../django4blog# python3 manage.py collectstatic
(env) ../django4blog# python3 manage.py migrate
至此,我们部署针对开发和代码这部分的工作已经结束了。
接下来就是启用Nginx并配置相关代理。
首先我们把Nginx的默认配置和连接文件default
先删除。
分别进入/etc/nginx/sites-available
,/etc/nginx/sites-enabled
两个文件夹输入命令:
sudo rm -r default
删除default
文件。
然后我们进入/etc/nginx/sites-available
新建一个我们自己的配置文件:django4blog
(myenv) root.../etc/nginx/sites-available# cd /etc/nginx/sites-available
(myenv) root.../etc/nginx/sites-available# vi django4blog
输入如下配置内容:
server {
charset utf-8;
listen 80;
server_name 39.107.240.223; # 改成你的 IP
location /static {
alias /root/django_project/django4blog/collected_static;
}
location / {
proxy_set_header Host $host;
proxy_pass http://unix:/tmp/39.107.240.223.socket; # 改成你的 IP
}
}
:wq
保存退出后输入命令
sudo ln -s /etc/nginx/sites-available/django4blog /etc/nginx/sites-enabled
接着检查下Nginx的配置文件的用户信息:
这个用户改成root
,否则可能会报403权限错误。
cd /etc/nginx#
,vi nginx.conf
修改用户为root
最后刷新下Nginx配置信息:
sudo service nginx reload
先回到项目所在的目录cd django_project/django4blog
,并且进入虚拟环境,输入命令创建一个超级账户:
python manage.py createsuperuser
然后安装gunicorn:
pip3 install gunicorn
启动gunicorn
,注意修改为自己的公网地址和自己的项目名称。
gunicorn --bind unix:/tmp/39.107.240.223.socket django4blog.wsgi:application
回到本地系统中,在浏览器输入地址:http://39.107.240.223/
成功运行!!
接着我们登录后台http://39.107.240.223/admin/ ,添加几条数据。
回到首页
阅读文章详情页