部署你的CRM程序 教你發佈CRM

 

教你發佈CRM

 

發佈CRM你將使用如下軟件javascript

  • nginx
  • uWSGI
  • CentOS7
  • CRM項目文件
  • virtualenv
  • supervisor

WSGI、uWSGI

python web服務器開發使用WSGI協議(Web Server Gateway Interface)html

python web項目默認會生成一個wsgi.py文件,肯定好應用模塊。java

生產環境中使用的是uWSGI,實現了WSGI全部接口,C語言編寫,效率很高的web服務器。python

uWSGI是一個全功能的HTTP服務器,實現了WSGI協議、uwsgi協議、http協議等。它要作的就是把HTTP協議轉化成語言支持的網絡協議。好比把HTTP協議轉化成WSGI協議,讓Python能夠直接使用。linux

Nginx

使用nginx是爲了它的反向代理功能,項目會經過Django+uWSGI+Nginx進行服務器線上部署。nginx

CentOS

1.打包項目CRM文件夾,壓縮文件web

2.經過xftp、scp、lrzsz等上傳文件至Centos服務器shell

Linux使用技巧

1.經過xshell或者iTerm等軟件,多終端操做你的linxu,這樣對uwsgi、nginx、項目代碼調試的時候,避免來回切換目錄,提供工做效率。django

2.注意修改了linux軟件的配置文件,都要重啓服務才能生效。後端

Virtualenv

構建一個乾淨,隔離的python解釋器環境,防止軟件依賴,衝突等問題,建議使用。

Supervisor

Supervisor(http://supervisord.org/)是用Python開發的一個client/server服務,是Linux/Unix系統下的一個進程管理工具,不支持Windows系統。它能夠很方便的監聽、啓動、中止、重啓一個或多個進程。用Supervisor管理的進程,當一個進程意外被殺死,supervisort監聽到進程死後,會自動將它從新拉起,很方便的作到進程自動恢復的功能,再也不須要本身寫shell腳原本控制。

項目部署

激活虛擬python環境

#建立基於python3的虛擬解釋器環境venv
virtualenv --no-site-packages --python=python3 venv
#激活python3虛擬環境
[root@yugo /data 11:11:30]#source venv/bin/activate
(venv) [root@yugo /data 11:11:35]#

安裝uwsgi

(venv) [root@yugo /data 11:13:23]#pip3 install uwsgi

配置啓動uwsgi.ini,啓動uwsgi時候,用這個配置文件啓動

複製代碼
(venv) [root@yugo /data 11:14:25]#cat uwsgi.ini
[uwsgi]
#使用nginx鏈接時使用
socket=0.0.0.0:8000
#不用nginx直接當作web服務器使用
#http=0.0.0.0:9000
#項目目錄絕對路徑
chdir=/data/Ace_crm
#wsgi文件路徑,在項目底下
wsgi-file=Ace_crm/wsgi.py #指定解釋器目錄 home=/data/venv processes=4 threads=2 master=True pidfile=uwsgi.pid daemonize=uwsgi.log
複製代碼

配置nginx

配置nginx.conf,經過nginx反向代理將請求丟給django處理

複製代碼
(venv) [root@yugo /data 11:20:32]#cat /opt/nginx1-12/conf/nginx.conf
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
    access_log  logs/access.log  main;
    sendfile        on;
    keepalive_timeout  65;
    #定義負載均衡池,名字叫作django,池子中寫入uwsgi發佈django的socket地址
    upstream django {
    server 0.0.0.0:8000;
}
    server {
        listen       80;
        server_name  pythonav.cn;
        #訪問nginx的根路徑時,轉發請求給uwsgi的8000端口,這裏要和uwsgi.ini寫的一致
        location / {
        include  /opt/nginx1-12/conf/uwsgi_params;
     #請求轉發給upstream地址池裏的uwsgi程序 uwsgi_pass
django; } location /static/ { alias /opt/nginx1-12/html/static/; } } }
複製代碼

熱加載nginx服務,讀取nginx.conf內容

(venv) [root@yugo /data 11:24:24]#/opt/nginx1-12/sbin/nginx -t
nginx: the configuration file /opt/nginx1-12/conf/nginx.conf syntax is ok
nginx: configuration file /opt/nginx1-12/conf/nginx.conf test is successful
(venv) [root@yugo /data 11:26:07]#/opt/nginx1-12/sbin/nginx -s reload

啓動uwsgi,啓動django

複製代碼
(venv) [root@yugo /data 11:26:54]#uwsgi --ini uwsgi.ini
[uWSGI] getting INI configuration from uwsgi.ini
(venv) [root@yugo /data 11:27:10]#ps -ef|grep uwsgi
root     15540     1  0 11:27 ?        00:00:00 uwsgi uwsgi.ini
root     15543 15540  0 11:27 ?        00:00:00 uwsgi uwsgi.ini
root     15544 15540  0 11:27 ?        00:00:00 uwsgi uwsgi.ini
root     15545 15540  0 11:27 ?        00:00:00 uwsgi uwsgi.ini
root     15546 15540  0 11:27 ?        00:00:00 uwsgi uwsgi.ini
root     15590 11958  0 11:27 pts/0    00:00:00 grep --color=auto uwsgi

#若是須要中止uwsgi可使用ps -ef|grep uwsgi,找到pid殺掉
#更好的一個殺掉uwsgi的方式
killall -9 uwsgi
複製代碼

訪問nginx的80端口,查看是否請求轉發給django

http://pythonav.cn/login/
或者10.0.0.10/login

配置nginx的靜態資源

爲何要配置靜態資源?

配置靜態資源目錄是由於讓靜態資源經過nginx能夠直接返回,不須要經過uwsgi,也就是讓uwsgi只處理後端邏輯,不處理靜態資源,優化性能

配置靜態資源,django和nginx

#建立靜態資源存放目錄
[root@yugo /opt/nginx1-12/html 11:39:51]#mkdir -vp /opt/nginx1-12/html/static
mkdir: created directory ‘/opt/nginx1-12/html/static
#給目錄添加權限
[root@yugo /opt/nginx1-12/html 11:40:57]#chmod  755 /opt/nginx1-12/html/static/

配置django的settings.py

複製代碼
DEBUG = False
ALLOWED_HOSTS = ['*']

# Static files (CSS, JavaScript, Images) # https:
//docs.djangoproject.com/en/1.11/howto/static-files/ STATIC_URL = '/static/' STATIC_ROOT= '/opt/nginx1-12/html/static/' STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ]
複製代碼

分割線--

收集django靜態文件

python3 manage.py collectstatic
這一句話就會把之前放在app下static中的靜態文件所有拷貝到 settings.py 中設置的 STATIC_ROOT 文件夾中

而後請求靜態資源就會去nginx配置的 location /static {alias /opt/nginx1-12/html/static/ } 尋找

 

 

以上步驟完成後,訪問服務器主機地址和端口,若是nginx.conf中配置的爲80端口,則地址欄不須要輸入端口,由於瀏覽器請求端口也是默認爲80端口,非80端口的須要本身在ip後面添加

 

完畢

相關文章
相關標籤/搜索