luffy的上線


購買服務器

# 購買阿里雲服務器
# 短期或是測試使用,創建 按量收費 服務器,可以隨時刪除,刪除后不再計費,但要保證賬戶余額100元以上

 

連接服務器

1)賬號
>: ssh root@39.99.192.127

2)密碼
>: ********

 

服務器命令

管理員權限
1)以下所有的服務器命令均可以在管理員權限下執行
>: sudo 命令
配置終端
1)編輯配置文件
>: vim ~/.bash_profile

2)將原來內容全部刪除掉
>: ggdG

3)進入編輯狀態:填入下方兩行
>: i

export PATH=$PATH:$HOME/bin
PS1='Path:\w\n>:'

4)退出編輯狀態
>: esc

5)保存修改並退出
>: :wq

6)生效配置
>: source ~/.bash_profile

 

重要

更新系統軟件包
>: yum update -y   更新源
安裝軟件管理包和可能使用的依賴
>: yum -y groupinstall "Development tools"   #開發者的工具包
>: yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel   #系統依賴的
檢測是否成功:會將git作為依賴安裝號
>: git

 

 

安裝Mysql:Docker安裝了

1)前往用戶根目錄
>: cd ~

2)下載mysql57
>: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

也可以本地上傳,這條命令要在本地終端上執行
>: scp -r C:\Users\dell\Desktop\pkg\mysql57-community-release-el7-10.noarch.rpm root@39.99.192.127:~

3)安裝mysql57
>: yum -y install mysql57-community-release-el7-10.noarch.rpm
>: yum -y install mysql-community-server
 Gkz:tY)!c51%
4)啟動mysql57並查看啟動狀態
>: systemctl start mysqld.service
>: systemctl status mysqld.service

5)查看默認密碼並登錄
>: grep "password" /var/log/mysqld.log
>: mysql -uroot -p

6)修改密碼
>: ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
>: ALTER USER 'root'@'localhost' IDENTIFIED BY 'Owen1234?';

 

 

安裝Redis:Docker安裝了

1)前往用戶根目錄
>: cd ~

2)下載redis-5.0.5
>: wget http://download.redis.io/releases/redis-5.0.5.tar.gz
>: scp -r C:\Users\dell\Desktop\pkg\redis-5.0.5.tar.gz root@39.99.192.127:~

3)解壓安裝包
>: tar -xf redis-5.0.5.tar.gz

4)進入目標文件
>: cd redis-5.0.5

5)編譯環境
>: make

6)復制環境到指定路徑完成安裝
>: cp -r ~/redis-5.0.5 /usr/local/redis  #將文件夾復制到 后面的文件夾

7)配置redis可以后台啟動:修改下方內容
>: vim /usr/local/redis/redis.conf

daemonize yes

8)完成配置修改
>: esc
>: :wq

9)建立軟連接
>: ln -s /usr/local/redis/src/redis-server /usr/bin/redis-server
>: ln -s /usr/local/redis/src/redis-cli /usr/bin/redis-cli

10)后台運行redis
>: cd /usr/local/redis
>: redis-server  &

ctrl + c

11)測試redis環境
>: redis-cli
ctrl + c

12)關閉redis服務
>: pkill -f redis -9

 

安裝Python3.6

1)前往用戶根目錄
>: cd ~

2)下載 或 上傳 Python3.6.7
# 服務器終端
>: wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz

# 本地終端,給服務器上傳
>: scp -r 本地Python-3.6.7.tar.xz ssh root@39.99.192.127:服務器路徑
>: scp -r C:\Users\dell\Desktop\pkg\Python-3.6.7.tar.xz ssh root@39.99.192.127~

3)解壓安裝包
>: tar -xf Python-3.6.7.tar.xz

4)進入目標文件
>: cd Python-3.6.7

5)配置安裝路徑:/usr/local/python3
>: ./configure --prefix=/usr/local/python3

6)編譯並安裝
>: make && sudo make install

7)建立軟連接:終端命令 python3,pip3
>: ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
>: ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3

8)刪除安裝包與文件:
>: rm -rf Python-3.6.7
>: rm -rf Python-3.6.7.tar.xz

 

 

配置pip源:阿里雲不用配置,默認配置阿里源

1)創建pip配置路徑
>: mkdir ~/.pip

2)進入目錄編輯配置文件:填入下方內容
cd ~/.pip && vim pip.conf

[global]
index-url = http://pypi.douban.com/simple
[install]
use-mirrors =true
mirrors =http://pypi.douban.com/simple/
trusted-host =pypi.douban.com

 

安裝uwsgi

1)在真實環境下安裝
pip3 install uwsgi

2)建立軟連接
ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

 

 

安裝虛擬環境

1)安裝依賴
>: pip3 install virtualenv
>: pip3 install virtualenvwrapper

2)建立虛擬環境軟連接
>: ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv

3)配置虛擬環境:填入下方內容
>: vim ~/.bash_profile

VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
source /usr/local/python3/bin/virtualenvwrapper.sh

4)退出編輯狀態
>: esc

5)保存修改並退出
>: :wq

6)更新配置文件內容
>: source ~/.bash_profile

7)虛擬環境默認根目錄:~/.virtualenvs

 

 

安裝Nginx

1)前往用戶根目錄
>: cd ~

2)下載nginx1.13.7
>: wget http://nginx.org/download/nginx-1.13.7.tar.gz

3)解壓安裝包
>: tar -xf nginx-1.13.7.tar.gz

4)進入目標文件
>: cd nginx-1.13.7

5)配置安裝路徑:/usr/local/nginx
>: ./configure --prefix=/usr/local/nginx

6)編譯並安裝
>: make && sudo make install

7)建立軟連接:終端命令 nginx
>: ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx

8)刪除安裝包與文件:
>: cd ~
>: rm -rf nginx-1.13.7
>: rm -rf nginx-1.13.7.tar.xz

9)測試Nginx環境,服務器運行nginx,本地訪問服務器ip
>: nginx
>: 服務器綁定的域名 或 ip:80

 

Nginx命令

1)啟動
>: nginx

2)關閉nginx
>: nginx -s stop

3)重啟nginx
>: nginx -s reload

4)查看端口,強行關閉
>: ps -aux|grep nginx
>: kill <pid:進程編號>

 

 

路飛項目部署:Nginx + uwsgi + django + vue

 

配置前台項目

上線前配置

settings.js
base_url: 'http://39.99.192.127:8000',  // 真實環境:django項目就是跑在8000端口上的

上線

"""
# 本地終端操作
1)本地項目打包,前往luffycity項目目錄下
>: cnpm run build

2)本地終端上傳
>: scp -r dist root@39.99.192.127:~

# 開始服務器連接,在服務器終端操作
3)移動並重命名
mv ~/dist /home/html

4)去向Nginx配置目錄,備份配置,完全更新配置:填入下方內容
>: cd /usr/local/nginx/conf
>: mv nginx.conf nginx.conf.bak
>: vim nginx.conf
>: i

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 80;
        server_name  127.0.0.1; # 改為自己的域名,沒域名修改為127.0.0.1:80
        charset utf-8;
        location / {
            root /home/html; # html訪問路徑
            index index.html; # html文件名稱
            try_files $uri $uri/ /index.html; # 解決單頁面應用刷新404問題
        }
    }
}   

5)退出
>: esc
>: :wq

6)重啟nginx
>: nginx -s reload
"""

 

 

路飛后台部署

本地操作

上線前配置

prod.py:上線的配置文件,內容拷貝dev.py,前身就是settings.py
# 關閉測試環境
DEBUG = False
ALLOWED_HOSTS = [
    '39.99.192.127'  # 公網ip地址
]

CORS_ORIGIN_ALLOW_ALL = True  # 允許所有跨域


# 靜態文件配置:上線后還有額外配置,見下方 后台樣式問題
STATIC_URL = '/static/'


# 后台http根路徑
# BASE_URL = 'http://127.0.0.1:8000'
BASE_URL = 'http://39.99.192.127:8000'
# 前台http根路徑
# LUFFY_URL = 'http://127.0.0.1:8080'
LUFFY_URL = 'http://39.99.192.127:80'
# 訂單支付成功的后台異步回調接口
NOTIFY_URL = BASE_URL + '/order/success/'
# 訂單支付成功的前台同步回調接口
RETURN_URL = LUFFY_URL + '/order/pay/success/'


REST_FRAMEWORK = {
    # 渲染模塊
    'DEFAULT_RENDERER_CLASSES': [
        'rest_framework.renderers.JSONRenderer',
        # 'rest_framework.renderers.BrowsableAPIRenderer',
    ],
    # ...
}
wsgi.py 、manage_prod.py該文件就是manage.py的一個副本)
# 需要做上線修改的內容
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.prod')

導出項目環境

1)進入本地項目根目錄
>: cd 項目根目錄

2)本地導出項目環境
>: pip3 freeze > packages.txt

3)如果環境中有特殊的安裝包,需要處理一下xadmin
packages.txt中的
	xadmin==2.0.1
要被替換為
	https://codeload.github.com/sshwsfc/xadmin/zip/django2

項目提交到遠程git倉庫

1)去向本地項目倉庫
>: cd 項目根目錄

2)本地版本庫操作
>: git status
>: git add .
>: git commit -m '項目2.0上線'

3)提交到遠程版本庫
>: git pull origin master
>: git push origin master

 

線上操作

git同步上線項目

1)創建存放后台項目的目錄
>: mkdir /home/project

2)進入后台項目管理目錄同步git倉庫中的項目
>: cd /home/project
>: git clone https://gitee.com/doctor_owen/luffyapi.git

項目虛擬環境

1)創建線上luffy項目虛擬環境
>: mkvirtualenv luffy
>: workon luffy

2)安裝所需環境,在packages.txt所在目錄下安裝執行packages.txt文件
>: pip install uwsgi
>: pip install -r /home/project/luffyapi/packages.txt

完成uwsgi與nginx后台項目配置

"""
1)進行uwsgi服務配置,內容如下
>: vim /home/project/luffyapi/luffyapi.xml

<uwsgi>    
   <socket>127.0.0.1:8808</socket> <!-- 內部端口,自定義 --> 
   <chdir>/home/project/luffyapi/</chdir> <!-- 項目路徑 -->            
   <module>luffyapi.wsgi</module>  <!-- luffyapi為wsgi.py所在目錄名--> 
   <processes>4</processes> <!-- 進程數 -->     
   <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
</uwsgi>

4)去向Nginx配置目錄,備份配置,完全更新配置:填入下方內容
>: vim /usr/local/nginx/conf/nginx.conf

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 80;
        server_name  127.0.0.1; # 改為自己的域名,沒域名修改為127.0.0.1:80
        charset utf-8;
        location / {
            root /home/html; # html訪問路徑
            index index.html; # html文件名稱
            try_files $uri $uri/ /index.html; # 解決單頁面應用刷新404問題
        }
    }
    # 新增的server
    server {
        listen 8000;
        server_name  127.0.0.1; # 改為自己的域名,沒域名修改為127.0.0.1:80
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1:8808;  # 端口要和uwsgi里配置的一樣
           uwsgi_param UWSGI_SCRIPT luffyapi.wsgi;  #wsgi.py所在的目錄名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 項目路徑
        }
    }
} 
"""

數據庫設置:docker中操作

1)管理員連接數據庫
>: mysql -uroot -pOwen1234?

2)創建數據庫
>: create database luffyapi default charset=utf8;

3)設置權限賬號密碼:賬號密碼要與項目中配置的一致
>: grant all privileges on luffyapi.* to 'luffyapi'@'%' identified by 'Luffy123?';
>: grant all privileges on luffyapi.* to 'luffyapi'@'localhost' identified by 'Luffy123?';
>: flush privileges;

4)退出mysql
>: quit;

完成項目的數據庫遷移:Django采用2.0.7

# 必須在luffy環境下
1)數據庫遷移
>: cd /home/project/luffyapi/
>: python manage_prod.py migrate

2)創建超級用戶
>: python manage_prod.py createsuperuser
# 賬號密碼:admin|Admin123

如何Django不是2.0.7的其他版本,數據庫遷移保存解決方案:修改源碼

1)修改base.py源碼
>: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/base.py

方案:36,37行注釋掉

2)修改operations.py源碼
>: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/operations.py

方案:146行添加
	query = query.encode()

啟動uwsgi,重啟nginx測試

"""
1)啟動uwsgi
>: uwsgi -x /home/project/luffyapi/luffyapi.xml

2)重啟nginx
>: nginx -s reload
"""

后台樣式:admin、rest_framework、xadmin等框架的靜態樣式也需要處理

修改線上配置
1)編輯線上配置文件
>: vim /home/project/luffyapi/luffyapi/settings/prod.py


2)修改static配置,新增STATIC_ROOT、STATICFILES_DIRS
STATIC_URL = '/static/'
STATIC_ROOT = '/home/project/luffyapi/luffyapi/static'  
STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),)

3)退出編輯
>: esc
>: :wq
遷移靜態樣式:項目目錄下
1)項目目錄下沒有 static 文件夾需要新建
>: mkdir /home/project/luffyapi/luffyapi/static

2)完成靜態文件遷移
>: python /home/project/luffyapi/manage_prod.py collectstatic
Nginx配置靜態路徑
1)修改nginx配置
>: vim /usr/local/nginx/conf/nginx.conf

events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 80;
        server_name  127.0.0.1; # 改為自己的域名,沒域名修改為127.0.0.1:80
        charset utf-8;
        location / {
            root /home/html; # html訪問路徑
            index index.html; # html文件名稱
            try_files $uri $uri/ /index.html; # 解決單頁面應用刷新404問題
        }
    }
    server {
        listen 8000;
        server_name  127.0.0.1; # 改為自己的域名,沒域名修改為127.0.0.1:80
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1:8808;  # 端口要和uwsgi里配置的一樣
           uwsgi_param UWSGI_SCRIPT luffyapi.wsgi;  #wsgi.py所在的目錄名+.wsgi
           uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 項目路徑
        }
        # 新增的配置靜態文件
        location /static {
            alias /home/project/luffyapi/luffyapi/static;
        }
    }
}

2)退出
>: esc
>: :wq
啟動服務
1)關閉 uwsgi,重新啟動 uwsgi
>: pkill -f uwsgi -9
>: uwsgi -x /home/project/luffyapi/luffyapi.xml

2)關閉 nginx,重新啟動 nginx
>: nginx -s stop
>: nginx

 

線上項目測試

1)本地瀏覽器訪問xadmin后台
http://39.99.192.127:8000/xadmin

2)登錄,錄入測試數據
# 賬號密碼:admin|Admin123

3)或是導出本地數據庫為sql,再在線上導入sql
>: mysql -h 39.99.192.127 -P 3306 -u luffy -p
>: Luffy123?
>: use luffy
>: 復制之前的數據備份

 

重點 重點 重點

# 1、真實環境和虛擬環境都要安裝uwsgi,將真實環境下的uwsgi建立軟連接

# 2、redis服務一定要后台啟動:redis-server &

# 3、uwsgi啟動django項目一定要進入虛擬環境下,因為環境都是安裝在虛擬環境中

# 4、服務器的日志都會被記錄在於uwsgi配置文件 luffyapi.xml 同類目下的 uwsgi.log 中

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM