1.1 下载地址
https://www.python.org/downloads/windows/
选择Windows x86-64 executable installer
下载解压:python-3.5.4-amd64.exe
问题:安装python-3.5.4-amd64.exe时报错:0x80240017
解决:重装系统:Windows8.1-KB2919355-x64.msu
下载Windows8.1-KB2919355-x64.msu:
https://pan.baidu.com/s/1Iw8y-jsbnrLyzUncua1lSQ#list/path=%2F
1.2 添加系统环境
如:C:\python35和C:\python35\Scripts
1.3 更新pip3
python -m pip install --upgrade pip --force-reinstall
1.4 安装项目依赖
先安装tornado:tornado-5.1.1-cp35-cp35m-win_amd64.whl 下载网址:https://pypi.org/project/tornado/5.1.1/#files pip3 install tornado-5.1.1-cp35-cp35m-win_amd64.whl 再安装项目依赖 pip3 install -r requirements.txt 注:这里会报错,执行1.6中的步骤进行安装
1.5 手动下载并安装mod_wsgi
下载网址:https://www.lfd.uci.edu/~gohlke/pythonlibs/#mod_wsgi 找到下载:mod_wsgi-4.5.24+ap24vc14-cp35-cp35m-win_amd64.whl pip3 install mod_wsgi-4.5.24+ap24vc14-cp35-cp35m-win_amd64.whl
1.6 没网的情况下安装依赖包
①下载:(直接在pycharm上项目路径下) pip3 download -d C:\Users\hzx\Desktop\package -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple/ 注:C:\Users\hzx\Desktop\package 指的是桌面上新建的空文件夹为package的路径, ②安装:把package文件夹和requirements.txt放在C盘根目录下 pip3 install --no-index --find-links=C:\package -r requirements.txt ③问题:安装过项目依赖后,执行python manage.py runserver 192.168.1.67:8000后会报错,提示xxx模块没有安装,
解决依次执行pip3 install 模块名==版本号 -i https://pypi.tuna.tsinghua.edu.cn/simple/
1.7 oracle_client安装解决
下载安装包(注意下载对应的版本,python是32位的还是64位的): ①cx_Oracle-5.3-11g.win32-py3.5.exe 下载地址:https://pypi.org/project/cx-Oracle/5.3/
下载之后双击安装下一步即可
②instantclient-basic-win32-11.1.0.7.0.zip 下载地址: https://www.oracle.com/database/technologies/instant-client/microsoft-windows-32-downloads.html ③解压instantclient-basic-win32-11.1.0.7.0.zip 得到 instantclient_11_1 复制oci.dll,oraocci11.dll,oraociei11.dll的3个文件粘贴到你的python目录的Libs/site-packages文件夹下面。 ④测试 import cx_Oracle 用自己的实际数据库用户名、密码、主机ip地址 替换即可 conn = cx_Oracle.connect('scott/tiger@192.168.100.211/oracle') curs = conn.cursor() sql = 'select * from DEPT' rr = curs.execute(sql) row = curs.fetchone() print(row[0]) curs.close() conn.close()
二、MySQL5.6安装
2.1 添加mysql的bin目录至系统环境
C:\Mysql56\bin
2.2 配置my.ini
创建my.ini文件,放在bin目录下面,配置内容: [mysql] default-character-set=utf8 # 设置mysql客户端默认字符集 [mysqld] port = 3306 # 设置3306端口 basedir=E:/Mysql56 # 设置mysql的安装目录 datadir=E:/Mysql56/data # 设置mysql数据库的数据的存放目录 max_connections=200 # 允许最大连接数 character-set-server=utf8 # 服务端使用的字符集默认为8比特编码的latin1字符集 default-storage-engine=INNODB # 创建新表时将使用的默认存储引擎
2.3 初始化数据库、安装并启动服务
mysqld --initialize-insecure mysqld -install 如果已存在,则删除:sc delete mysql 或者 mysql –remove net start mysql
2.4 初始化登录密码
mysqladmin -u root -p password 回车 出现Enter password:直接回车,未设置密码时默认没有密码, 接着出现“New password:”输入新的密码password,回车即可, 接着出现“Confirm new password:”确认密码password,回车即可。 登录mysql:mysql –uroot –ppassword
2.5 删除无用配置
delete from mysql.user where user=''; delete from mysql.user where host='::1';
2.6 令所用用户可以访问
update user set host='%' where user ='root'; flush privileges;
2.7 导入项目数据库
①先创建数据库 mysql –uroot –ppassword create database tesudrm_adg charset=utf8;
②导入项目数据库 mysql -uroot -ppassword tesudrm_adg < tesudrm_adg.sql
三、Redis3.2.1安装
3.1 下载地址
https:///MSOpenTech/redis 版本:Redis-x64-3.2.100
3.2 解压安装
3.3 启动
先修改配置文件redis.windows.conf: ①注释bind:172.0.0.1 ②requirepass redis密码(tesunet)
redis-server redis.windows.conf 指定配置文件开启
3.4 设置redis服务(开机自启)
redis-server --service-install redis.windows.conf --loglevel verbose
3.5 常用命令
卸载服务:redis-server --service-uninstall 开启服务:redis-server --service-start 停止服务:redis-server --service-stop
3.6 测试
redis-cli -h 127.0.0.1 -p 6379或者redis-cli 注意:如果redis-windows.conf中设置了密码:requirepass:tesunet。则登录命令为:redis-cli -a tesunet 127.0.0.1:6379>ping PONG 127.0.0.1:6379>select * from users
注:检验服务端是否启动成功,登录客户端执行ping命令,结果出现PONG则服务端启动成功
四、Apache安装
4.1 解压下载的压缩包
https://de.apachehaus.com/downloads/httpd-2.4.41-o102s-x64-vc14-r2.zip 解压httpd-2.4.41-o102s-x64-vc14-r2.zip 将解压出的Apache24移植指定位置C盘根路径:C:\
4.2 修改配置文件
cd C:\ Apache24\conf\httpd.conf ①Apache24文件的路径,其余不用改: Define SRVROOT "C:\Apache24"
②此处为你要发布的网站ip地址,此处我用我电脑的ip和端口,你也可以用127.0.0.1:8000用于本地测试;80端口自己设置 Listen 192.168.1.67:80 ServerName 192.168.1.67:80
③注释: # Define ENABLE_TLS13 "Yes"
4.3 创建apache服务(管理员权限开启终端)
①cd C:\Apache24\bin ②创建服务:httpd.exe -k install -n "Apache24" ③卸载服务:httpd.exe -k uninstall -n "Apache24" ④重启apache命令:httpd.exe -k restart
4.4 访问测试
192.168.1.67:8000 出现页面,则Apache服务配置成功
4.5 配置mod_wsgi
①查看mod_wsgi路径 mod_wsgi-express module-config
②记录下来 LoadFile "C:/python35/python35.dll" LoadModule wsgi_module "C:/python35/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd" WSGIPythonHome "C:/python35"
五、项目TSDRM_ADG
5.1 拷贝项目到C盘根目录下
5.2 设置django静态文件路径
①settings.py文件中写入静态文件物理路径(已经写了) SITE_ROOT=os.path.join(os.path.abspath(os.path.dirname(__file__)),'..') STATIC_ROOT = os.path.join(SITE_ROOT,'static')
②添加静态文件访问逻辑路径 STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ]
③收集静态文件 python manage.py collectstatic
④注销掉物理路径 # STATIC_ROOT # SITE_ROOT
5.3 修改配置文件httpd.conf
①安装wsgi模块后,出来的三行字符,直接复制过来 LoadFile "C:/python35/python35.dll" LoadModule wsgi_module "C:/python35/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd" WSGIPythonHome "C:/python35"
②设置项目中的wsgi路径 WSGIScriptAlias / C:\TSDRM_ADG\TSDRM\wsgi.py
③设置项目路径 WSGIPythonPath C:\TSDRM_ADG
④设置wsgi路径 <Directory C:\TSDRM_ADG\TSDRM> <Files wsgi.py> Require all granted </Files> </Directory>
⑤设置静态文件路径 Alias /static C:\TSDRM_ADG\static <Directory C:\TSDRM_ADG\static> AllowOverride None Options None Require all granted </Directory>
5.4 访问项目:192.168.1.67:8000
①问题:Forbidden You don't have permission to access this resource.
解决:
找到 apache 配置文件 httpd.conf
把里面的
<Directory />
AllowOverride none
Require all denied
</Directory>
改为
<Directory />
AllowOverride none
Require all granted
</Directory>
②问题:
Internal Server Error
The server encountered an internal error or misconfiguration and was unable to complete your request.
Please contact the server administrator, add.com@phpstudy and inform them of the time the error occurred, and anything you might have done that may have caused the error
查看问题:进入到C:\Apache24\logs
查看error.log,报错信息:
File "C:\\python35\\lib\\site-packages\\django\\__init__.py", line 17, in setup\r
configure_logging(settings.LOGGING_CONFIG, settings.LOGGING)\r
File "C:\\python35\\lib\\importlib\\__init__.py", line 126, in import_module\r
cursor.execute(sql)\r
File "C:\\python35\\lib\\site-packages\\pymysql\\cursors.py", line 165, in execute\r
result = self._query(query)\r
File "C:\\python35\\lib\\site-packages\\pymysql\\cursors.py", line 321, in _query\r
conn.query(q)\r
File "C:\\python35\\lib\\site-packages\\pymysql\\connections.py", line 860, in query\r
self._affected_rows = self._read_query_result(unbuffered=unbuffered)\r
pymysql.err.InternalError: (1046, 'No database selected')\r
解决:路径出错
进入到项目settings.py中:
注释:db_config_file = os.path.join(os.path.join(os.path.join(os.getcwd(), "faconstor"), "config"), "db_config.xml")
改为:db_config_file = r'C:\TSDRM_ADG\faconstor\config\db_config.xml'
5.5 下载wkhtmltopdf应用软件
①地址:https:///wkhtmltopdf/wkhtmltopdf/releases/ ②下载对应的应用软件:wkhtmltox-0.12.5-1.msvc2015-win64.exe ③将wkhtmltopdf应用软件拷贝至Apach24目录
将wkhtmltopdf应用软件拷贝纸Apache24/faconstor目录下
新建文件夹faconstor,将收集到的静态文件夹static拷贝一份至faconstor
参考:


## Windows下django+apache+mysql+redis项目部署
#### 1.Python3.54安装
```text
1.从官网下载可执行安装文件
https://www.python.org/downloads/windows/
选择Windows x86-64 executable installer
# 预安装基础模块
2.添加系统环境
如:C:\Python\python27和C:\Python\python27\Scripts
3.更新pip3
python -m pip install --upgrade pip --force-reinstall
4.安装项目依赖
# 先安装tornado
pip3 install tornado-5.1.1-cp35-cp35m-win_amd64.whl
pip3 install -r requirements.txt
5.手动下载并安装mod_wsgi
pip3 install mod_wsgi-4.5.24+ap24vc14-cp35-cp35m-win_amd64.whl
6.没网的情况下安装依赖包
# 下载
pip3 download -d C:\Users\Administrator\Desktop\package -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple/
# 安装
pip3 install --no-index --find-links=C:\Users\Administrator\Desktop\package -r requirements.txt
```
#### 2.MySQL5.6安装
```text
1.添加mysql的bin目录至系统环境
C:\Application\MySQL\mysql-5.6.45-winx64\bin
2.创建一个my.ini的文件,放在mysql目录里面,内容如下
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=E:/mysql-5.7.12-winx64
# 设置mysql数据库的数据的存放目录
datadir=E:/mysql-5.7.12-winx64/data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
wait_timeout=31536000
interactive_timeout=31536000
3.初始化数据库、安装并启动服务
mysqld --initialize-insecure
mysqld -install # 如果已存在,则删除:sc delete mysql 或者 mysql -remove
net start mysql
4.初始化登录密码
mysqladmin -u root password *******
5.删除无用配置
delete from mysql.user where user='';
delete from mysql.user where host='::1';
6.令所用用户可以访问
update user set host='%' where user ='root';
flush privileges;
7.导入项目数据库(先创建数据库)
mysql -uroot -p jx_tesudrm < jx_tesudrm.sql
```
#### 3.Redis3.2.1安装
```text
# 官网下载地址:http://redis.io/download
# github下载地址:https:///MSOpenTech/redis/tags |Redis-x64-3.2.100
# 1.解压
# 2.启动:
redis-server redis.windows.conf # 指定配置文件开启
# 3.设置redis服务(开机自启):
redis-server --service-install redis.windows.conf --loglevel verbose
# 4.常用命令:
# 卸载服务:redis-server --service-uninstall
# 开启服务:redis-server --service-start
# 停止服务:redis-server --service-stop
# 5.测试:
redis-cli.exe -h 127.0.0.1 -p 6379
>> ping
>> pong
```
#### 4.Apache安装
```text
1.解压下载的压缩包:
httpd-2.4.41-o102s-x64-vc14-r2.zip
# 将解压出的apache24移植指定位置
2.修改配置文件
C:\Application\Apache24\conf\httpd.conf
Define SRVROOT "C:\Apache24" #Apache24文件的路径,其余不用改。
Listen 192.168.184.146:8000 #此处为你要发布的网站ip地址,此处我用我电脑的ip和端口,你也可以用127.0.0.1:8000用于本地测试;80端口自己设置
ServerName 192.168.184.146:8000
3.创建apache服务(管理员权限开启终端) # Define ENABLE_TLS13 "Yes"
httpd.exe -k install -n "apache2.4" #apache2.4是所创建服务器名称,可更改。
# 重启apache命令:httpd.exe -k restart
4.访问测试:192.168.184.146:8000
5.配置mod_wsgi
5.1 查看mod_wsgi路径
mod_wsgi-express module-config
>> 记录下来
LoadFile "c:/application/python35/python35.dll"
LoadModule wsgi_module "c:/application/python35/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd"
WSGIPythonHome "c:/application/python35"
5.2 设置django静态文件路径
# settings.py文件中写入静态文件物理路径(已经写了)
SITE_ROOT=os.path.join(os.path.abspath(os.path.dirname(__file__)),'..')
STATIC_ROOT = os.path.join(SITE_ROOT,'static')
# 添加静态文件访问逻辑路径
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static')
]
# 收集静态文件
python3 manage.py collectstatic
# 注销掉物理路径
# STATIC_ROOT,SITE_ROOT
5.2 修改配置文件httpd.conf mod_wsgi-express module-config
#安装wsgi模块后,出来的三行字符,直接复制过来
LoadFile "c:/application/python35/python35.dll"
LoadModule wsgi_module "c:/application/python35/lib/site-packages/mod_wsgi/server/mod_wsgi.cp35-win_amd64.pyd"
WSGIPythonHome "c:/application/python35"
#设置工程中的wsgi路径
WSGIScriptAlias / C:\Pro\Tools\TSDRM\TSDRM\wsgi.py
#设置工程路径
WSGIPythonPath C:\Pro\Tools\TSDRM
#设置wsgi路径
<Directory C:\Pro\Tools\TSDRM\TSDRM>
<Files wsgi.py>
Require all granted
</Files>
</Directory>
#设置静态文件路径
Alias /static C:\Pro\Tools\TSDRM\static
<Directory C:\Pro\Tools\TSDRM\static>
AllowOverride None
Options None
Require all granted
</Directory>
5.3 urls.py 静态文件反向代理
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
urlpatterns += staticfiles_urlpatterns()
6.注意:不要导入 win_unicode_console
7.将wkhtmltopdf应用软件拷贝至apache目录下
# 新建文件faconstor
拷贝static文件夹至faconstor
8.celery在windows下重启自动启动
进入文件夹:
win7:C:\Users\Administrator\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup
win10:C:\ProgramData\Microsoft\Windows\Start Menu\Programs\StartUp
放入bat脚本:
cmd /k "cd /d D:\Pros\TSDRM && python manage.py runserver"
















