django+uwsgi+nginx阿里云服务器部署

*注:转载自:

https://www.cnblogs.com/znn041622/p/11145952.html

一.环境介绍:

    (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/cd/home/git/ mkdir .ssh

cd.sshcd.ssh vi authorized_keys

需要先检测是否有.ssh目录,将公匙保存在文件里,然后退出。

(3)测试,创建一个仓库,常识获取:

cd/varcd/var chown -R git:git git

chmod777gitchmod777git 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阿里云服务器部署)