部署是基於:centos7+nginx+uwsgi+python3+django 之上作的
1,詳細步驟(下面步驟都是ROOT權限執行):mysql
1、更新系統軟件包nginx
yum update -y
2、安裝軟件管理包和可能使用的依賴web
yum -y groupinstall "Development tools" yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel
3、下載Pyhton3到/usr/local 目錄redis
wget https://www.python.org/ftp/python/3.6.3/Python-3.6.3.tgz
解壓sql
tar -zxvf Python-3.6.3.tgz
cd Python-3.6.3
編譯安裝到指定路徑數據庫
./configure --prefix=/usr/local/python3
/usr/local/python3 路徑能夠本身指定,本身記着就行,下邊要用到。django
安裝python3windows
make make install
安裝完成以後 創建軟連接 添加變量 方便在終端中直接使用python3
ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
Python3安裝完成以後pip3也一塊安裝完成,不須要再單獨安裝
同樣創建軟連接
ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3
4、查看Python3和pip3安裝狀況
5、安裝virtualenv ,建議你們都安裝一個virtualenv,方便不一樣版本項目管理。
pip3 install virtualenv
創建軟連接
ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv
安裝成功在根目錄下創建兩個文件夾,主要用於存放env和網站文件的。(我的習慣,其它人可根據本身的實際狀況處理)
mkdir -p /data/env mkdir -p /data/wwwroot
6、切換到/data/env/下,建立指定版本的虛擬環境。
virtualenv --python=/usr/bin/python3 pyweb
而後進入/data/env/pyweb/bin
啓動虛擬環境:
source activate
留意我標記的位置,出現(pyweb),說明是成功進入虛擬環境。
CentOS7安裝MySQL(完整版)
1 下載並安裝MySQL官方的 Yum Repository
wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
2, 使用上面的命令就直接下載了安裝用的Yum Repository,大概25KB的樣子,而後就能夠直接yum安裝了。
yum -y install mysql57-community-release-el7-10.noarch.rpm
3,安裝MySQL服務器
yum -y install mysql-community-server
4, MySQL數據庫設置
首先啓動MySQL
systemctl start mysqld.service
查看MySQL運行狀態,運行狀態如圖:
systemctl status mysqld.service
此時MySQL已經開始正常運行,不過要想進入MySQL還得先找出此時root用戶的密碼,經過以下命令能夠在日誌文件中找出密碼:
grep "password" /var/log/mysqld.log
以下命令進入數據庫:
mysql -uroot -p
輸入初始密碼(是上面圖片最後面的 no;e!5>>alfg),此時不能作任何事情,由於MySQL默認必須修改密碼以後才能操做數據庫:
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
其中‘new password’替換成你要設置的密碼,注意:密碼設置必需要大小寫字母數字和特殊符號(,/';:等),否則不能配置成功
redis安裝
下載安裝包
wget http://download.redis.io/releases/redis-4.0.2.tar.gz
解壓安裝包並安裝
tar xzf redis-4.0.2.tar.gz cd redis-4.0.2 make make install
5, 開啓mysql的遠程訪問
執行如下命令開啓遠程訪問限制(注意:下面命令開啓的IP是 192.168.0.1,如要開啓全部的,用%代替IP):
grant all privileges on *.* to 'root'@'192.168.0.1' identified by 'password' with grant option;
而後再輸入下面兩行命令
mysql> flush privileges; mysql> exit
而後在windows遠程測試(也能夠用可視化第三方navcat等)
mysql -h 148.70.75.219 -P 3306 -uroot -p
最後開始進行項目配置
1,安裝uwsgi
pip install uwsgi
2,配置uwsgi,在項目根目錄下(manage.py同層目錄),新建uwsgi.ini
而後啓動uwsgi
uwsgi -i uwsgi.ini
咱們查下是否啓動成功
經過查詢日誌,成功運行,證實配置沒有問題
配置項目靜態文件
修改你的dango setting.py
DEBUG = False ALLOWED_HOSTS = ['*']
STATIC_ROOT = os.path.join(BASE_DIR,'static') #靜態文件收集 配置路徑且將 STATICFILES_DIRS 註釋
而後收集你項目裏的全部靜態文件,
python manage.py collectstatic
3,安裝nginx
切進 該 /usr/local/ 目錄下,執行下面命令
wget http://nginx.org/download/nginx-1.13.7.tar.gz
下載完成後,執行解壓命令:
tar -zxvf nginx-1.13.7.tar.gz
進入解壓後的nginx-1.13.7文件夾,依次執行如下命令:
./configure make make install
nginx通常默認安裝好的路徑爲/usr/local/nginx
在/usr/local/nginx/conf/中先備份一下nginx.conf文件,以防意外。
cp nginx.conf nginx.conf.bak
而後打開nginx.conf,把原來的內容刪除,直接加入如下內容:
配置完成後,啓動nginx
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf #啓動nginx ./nginx -s reload #重啓nginx (/usr/local/nginx/sbin下)
./nginx #啓動nginx
查詢是否啓動成功
lsof -i:8000 查端口占用 ps -ef|grep nginx 查端口號 pkill -9 nginx 強制中止運行
如今打開瀏覽器便可進行訪問。