django+uwsgi+nginx阿里云服务器部署
Posted znn041622
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django+uwsgi+nginx阿里云服务器部署相关的知识,希望对你有一定的参考价值。
一.环境介绍:
(1)阿里云cms(ubumtu18.0.1)
(2) git
(3)mysql5.7
(4)python
(5) uwsgi
(6) nginx
(7)django2.0
二:环境配置:
1.安装前准备工作:
(1)因为阿里云服务器安全要求比较高,因此,需要登录后台服务器,去安全组设置开放接口,
需要开放3306(数据库),22(22)ssh后续连接,80(http)服务,此外打开3000-9000端口。
(2)开启FTP服务,方便后续上传文件和安装包。
2.git安装以及相关设置
sudo apt-get install git
2.1文件保存到github上。
(1)注册github账户,同时下载bendigit客户端
(2)在git客户端做基本配置,自己的名字和邮箱:
git config --global user.name "yourname"
git config --global user.email "youremail"
(3)二、生成SSH密钥过程:
1.查看是否已经有了ssh密钥:cd ~/.ssh如果没有密钥则不会有此文件夹,有则备份删除
2.生成密钥:$ ssh-keygen -t rsa -C “yourenail”按3个回车,密码为空。可以看到如下内容:
“Your identification has been saved in /home/tekkub/.ssh/id_rsa.
Your public key has been saved in /home/tekkub/.ssh/id_rsa.pub.
The key fingerprint is:………………最后得到了两个文件:id_rsa和id_rsa.pub”
文件在用户/users/username/.ssh下。
3.登录github,点击settings,添加密钥到ssh:ssh-add,添加的是“id_rsa.pub”里面的公钥。
5.测试:ssh [email protected],出现如下内容说明测试连接成功:
“The authenticity of host ‘github.com (207.97.227.239)’ can’t be established.RSA key fingerprint is 16:27:ac:a5:76:28:2d:36:63:1b:56:4d:eb:df:a6:48.Are you sure you want to continue connecting (yes/no)? yesWarning: Permanently added ‘github.com,207.97.227.239′ (RSA) to the list of known hosts.ERROR: Hi tekkub! You’ve successfully authenticated, but GitHub does not provide shell accessConnection to github.com closed.”
git安装成功
2.2搭建自己的git服务器:
(1)创建git用户和权限:
添加用户:adduser git
修改权限:vi /etc/passwd
找到文件:git:x:1001:1001:,,,:/home/git:/bin/bash做修改如下:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shel
(2)创建git公钥匙:
同上述步骤3.1步骤的1和2.复制id_rsa.pub内容,回到服务器操作:
$ cd /home/git/
$ mkdir .ssh
$ cd .ssh
$ vi authorized_keys
需要先检测是否有.ssh目录,将公匙保存在文件里,然后退出。
(3)测试,创建一个仓库,常识获取:
$ cd /var
$ chown -R git:git git
$chmod 777 git
$ cd git
接下来,我们用git命令初始化一个仓库:
$ git init --bare arepoforyourproject.git
回到你本地的电脑上,我们通过克隆来试试仓库是否可以使用:
$ git clone [email protected]:/var/git/arepoforyourproject.git
然后会提示你输入git的密码(创建用户时的密码),输入进去,
git服务器已经OK了。
3.数据库安装:
sudo apt-get install mysql
sudo apt-get update
sudo apt-get install mysql-server
sudo apt-get install mysql-client (安装过程中需要设置密码:123456)
sudo apt-get install libmysqlclient-dev
安装完成以后,输入:mysql -uroot -p 回车 输入密码看能否进行正常的本地登录。
如果无法登陆(确认服务器打开了3306端口):
3.1修改mysql监听IP:
vim /etc/mysql/mysql.conf.d/mysqld.cnf
找到bind-address,如果监听固定远程IP,则改成远程主机IP,
若监听所有IP,则改成0.0.0.0或者注释bind-address:
service mysql restart
查看MySQL监听地址:
netstat -ano | grep 3306,看到:
tcp 0 0.0.0:3306 0.0.0.01:*(配置监听所有人)
监听成功
3.2远程登录实现:
grant all privileges on *.* to ‘用户‘@‘ip‘ identified by ‘密码‘ with grant option;
flush privileges;
第一句语句语句中,*.*代表所有库表,若想给予所有IP权限, ”ip”写成“%”,所以第一句sql的意思是给予来自所有IP地址的通过“用户”, “密码”登录的用户对所有库表的所有操作权限。 第二句sql,刷新权限。
service mysql restart
然后同样重启MySQL生效。
3.3 mysql -u ‘user’ -p,然后输入密码就可以登陆成功。
mysql安装成功
4.python安装:
系统自带了2.7版本,以及3.6.7.项目使用3.6.2,因此,采用编译安装3.6.2版本的python:
(1)依赖库的预安装:
sudo apt-get install gcc make zlib1g-dev
sudo apt-get install libbz2-dev
sudo apt-get install libsqlite3-dev
sudo apt-get install python3-dev libxml2-dev libffi-dev libssl-dev libxslt1-dev
(2)安装:
获取python包:
wget https://www.python.org/ftp/python/3.6.2/Python-3.6.2.tar.xz
或者下载本地,通过ftp上传服务器
解压:
tar xJf Python-3.6.1.tar.xz
进入目录配置:
./configure --prefix=/usr/python3
编译:
make
安装:sudo -H make install
建立链接:
ln -s /usr/python/bin/python3 /usr/bin/python3
python3安装成功。
4.1虚拟环境建立:
apt-get install virtaulenv
apt-get install virtualenvwrapper
安装完virtualenvwrapper后,还需要配置virtualenvwrapper的环境变量。
首先通过which virtualenvwrapper.sh命令查看virtualenvwrapper.sh文件所在的路径。
在当前用户目录下创建.virtualenv文件夹,用来存放所有的虚拟环境目录。
在当前用户目录下编辑.bashrc文件,添加以下代码:
export WORKON_HOME=$HOME/.virtualenvs
source /usr/local/bin/virtualenvwrapper.sh
然后退出bashrc文件,输入命令source ~/.bashrc。
5.安装uwsgi:
pip3 install uwsgi
6.安装nginx:
apt-get install nginx
三.部署自己的项目到服务器上:
本地工作:
(1)确认项目没有bug。
(2)用pip freeze > requirements.txt将当前环境的包导出到requirements.txt文件中,方便部署的时候安装。
(3)项目上传到github或者自己服务器:
git init 初始化仓库
git add . 批量跟踪仓库文件
git commit -m ‘提交说明‘(必须要写)
创建一个远程仓库:
git remote add origin xxx.git (仓库地址)
将本地仓库中的代码提交到远程服务器的master分支上
git push -u origin master(首次提交需要加-u)
服务器端工作:
(1)mkvirtualenv --python=/usr/bin/python3 xfz-env 新建虚拟环境
(2)进入虚拟环境:
git init
创建一个远程仓库:
git remote add origin xxx.git (仓库地址)
git pull origin master
pip install -r requirements.txt
(3)进入mysql数据库中,创建好项目的数据库。
执行python manage.py makemigrations/migrate将模型映射到数据库中。
执行python manage.py runserver 0.0.0.0:8000,然后在自己电脑上访问这个网站,确保没有BUG。
在settings.py中的ALLOWED_HOST添加网站的域名或者ip地址。
设置DEBUG=False,避免如果你的网站产生错误,而将错误信息暴漏给用户。
在settings.py中配置STATIC_ROOT
(4)执行git命令,更新到服务器上:
当前目录下新建文件夹:STATIC_ROOT,并且执行python manage.py collectstatic
执行python manage.py runserver 0.0.0.0:8000,然后在自己电脑上访问这个网站,确保没有BUG
(5)当前目录下创建uwsgi,ini(修改项目路径,home,按照自己项目的路径):
[uwsgi]
# 必须全部为绝对路径
# 项目的路径
chdir = /srv/beike/xfz
# Django的wsgi文件
module = xfz.wsgi
# Python虚拟环境的路径
home = /root/.virtualenvs/xfz-env
# 进程相关的设置
# 主进程
master = true
# 最大数量的工作进程
processes = 10
http = :8000
# 设置socket的权限
chmod-socket = 666
# 退出的时候是否清理环境
vacuum = true
daemonize = /var/log/xfz_uwsgi.log
然后通过命令uwsgi --ini uwsgi.ini运行,确保没有错误。然后在浏览器中访问http://ip地址:8000,如果能够访问到页面(可能没有静态文件)说明uwsgi配置没有问题
(6)在/etc/nginx/conf.d目录下,新建一个文件,叫做zhiliaoketang.conf(根据自己情况也可以叫其他名字,
修改server 后的路径到自己的项目路径,server_name到自己的项目名):
upstream zhiliaoketang
server unix:///srv/zhiliaoketang/zhiliaoketang.sock;
# 配置服务器
server
# 监听的端口号
listen 80;
# 域名
server_name 192.168.0.101;
charset utf-8;
# 最大的文件上传尺寸
client_max_body_size 75M;
# 静态文件访问的url
location /static
# 静态文件地址
alias /srv/zhiliaoketang/static_dist;
# 最后,发送所有非静态文件请求到django服务器
location /
uwsgi_pass zhiliaoketang;
# uwsgi_params文件地址
include /etc/nginx/uwsgi_params;
service nginx configtest,如果ok说明成功了
service nginx restart
在返回到项目目录,打开uwsgi:
注释掉:
“http = :8000”,并添加:
“socket = srv/zhiliaoketang/zhiliaoketang.sock”(该内容需要与zhiliaoketang.conf下面的upstream
中配置路径保持一致)。
至此,整个配置完成。
以上是关于django+uwsgi+nginx阿里云服务器部署的主要内容,如果未能解决你的问题,请参考以下文章
阿里云 centos7 django + uWSGI+Nginx + python3 部署攻略