1. # 购买阿里云服务器
  2. # 短期或是测试使用,创建 按量收费 服务器,可以随时删除,删除后不再计费,但要保证账户余额100元以上

安全组设定:开放需要用到的端口

  1. 1)账号
  2. >: ssh root@101.132.27.14
  3.  
  4. 2)密码
  5. >: ********
  1. 1)以下所有的服务器命令均可以在管理员权限下执行
  2. >: sudo 命令
  1. 1)编辑配置文件
  2. >: vim ~/.bash_profile
  3. 2)将原来内容全部删除掉
  4. >: ggdG
  5. 3)进入编辑状态:填入下方两行
  6. >: i
  7. export PATH=$PATH:$HOME/bin
  8. PS1='Path:\w\n>:'
  9.  
  10. 4)退出编辑状态
  11. >: esc
  12. 5)保存修改并退出
  13. >: :wq
  14. 6)生效配置 (重新加载 ~根目录)
  15. >: source ~/.bash_profile

 

  1. >: yum update -y
  1. >: yum -y groupinstall "Development tools"
  2. >: yum install openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel psmisc libffi-devel
  1. >: git

 

  1. 1)前往用户根目录
  2. >: cd ~
  3.  
  4. 2)下载mysql57
  5. >: wget http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
  6. 也可以本地上传,这条命令要在本地终端上执行
  7. >: scp -r C:\Users\dell\Desktop\pkg\mysql57-community-release-el7-10.noarch.rpm root@101.132.27.14:~
  8.  
  9. 3)安装mysql57
  10. >: yum -y install mysql57-community-release-el7-10.noarch.rpm
  11. >: yum -y install mysql-community-server
  12. 4)启动mysql57并查看启动状态
  13. >: systemctl start mysqld.service
  14. >: systemctl status mysqld.service
  15. 5)查看默认密码并登录
  16. >: grep "password" /var/log/mysqld.log
  17. >: mysql -uroot -p
  18. 6)修改密码
  19. >: ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
  20. >: ALTER USER 'root'@'localhost' IDENTIFIED BY 'Owen1234?';

 

  1. 1)前往用户根目录
  2. >: cd ~
  3.  
  4. 2)下载redis-5.0.5
  5. >: wget http://download.redis.io/releases/redis-5.0.5.tar.gz
  6. >: scp -r C:\Users\dell\Desktop\pkg\redis-5.0.5.tar.gz root@101.132.27.14:~
  7.  
  8. 3)解压安装包
  9. >: tar -xf redis-5.0.5.tar.gz
  10. 4)进入目标文件
  11. >: cd redis-5.0.5
  12.  
  13. 5)编译环境
  14. >: make
  15. 6)复制环境到指定路径完成安装
  16. >: cp -r ~/redis-5.0.5 /usr/local/redis
  17. 7)配置redis可以后台启动:修改下方内容
  18. >: vim /usr/local/redis/redis.conf
  19. daemonize yes
  20. 8)完成配置修改
  21. >: esc
  22. >: :wq
  23. 9)建立软连接
  24. >: ln -s /usr/local/redis/src/redis-server /usr/bin/redis-server
  25. >: ln -s /usr/local/redis/src/redis-cli /usr/bin/redis-cli
  26. 10)后台运行redis
  27. >: cd /usr/local/redis
  28. >: redis-server ./redis.conf &
  29. ctrl + c
  30. 11)测试redis环境
  31. >: redis-cli
  32. ctrl + c
  33. 12)关闭redis服务
  34. >: pkill -f redis -9

 

  1. 1)前往用户根目录
  2. >: cd ~
  3.  
  4. 2)下载 上传 Python3.6.7
  5. # 服务器终端
  6. >: wget https://www.python.org/ftp/python/3.6.7/Python-3.6.7.tar.xz
  7. # 本地终端,给服务器上传
  8. >: scp -r 本地Python-3.6.7.tar.xz ssh root@101.132.27.14:服务器路径
  9. >: scp -r C:\Users\dell\Desktop\pkg\Python-3.6.7.tar.xz ssh root@101.132.27.14:~
  10.  
  11. 3)解压安装包
  12. >: tar -xf Python-3.6.7.tar.xz
  13. 4)进入目标文件
  14. >: cd Python-3.6.7
  15.  
  16. 5)配置安装路径:/usr/local/python3
  17. >: ./configure --prefix=/usr/local/python3
  18. 6)编译并安装 前面执行完才执行后面 如果是|| 不管前面成功与否都执行后面
  19. >: make && sudo make install
  20. 7)建立软连接:终端命令 python3pip3
  21. >: ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3
  22. >: ln -s /usr/local/python3/bin/pip3.6 /usr/bin/pip3
  23. 8)删除安装包与文件:
  24. >: rm -rf Python-3.6.7
  25. >: rm -rf Python-3.6.7.tar.xz

 

  1. 1)创建pip配置路径
  2. >: mkdir ~/.pip
  3. 2)进入目录编辑配置文件:填入下方内容
  4. cd ~/.pip && vim pip.conf
  5. [global]
  6. index-url = http://pypi.douban.com/simple
  7. [install]
  8. use-mirrors =true
  9. mirrors =http://pypi.douban.com/simple/
  10. trusted-host =pypi.douban.com

 

  1. 1)在真实环境下安装
  2. pip3 install uwsgi
  3. 2)建立软连接
  4. ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi

 

  1. 1)安装依赖
  2. >: pip3 install virtualenv
  3. >: pip3 install virtualenvwrapper
  4. 2)建立虚拟环境软连接
  5. >: ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv
  6. 3)配置虚拟环境:填入下方内容
  7. >: vim ~/.bash_profile
  8. VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
  9. source /usr/local/python3/bin/virtualenvwrapper.sh
  10. 4)退出编辑状态
  11. >: esc
  12. 5)保存修改并退出
  13. >: :wq
  14. 6)更新配置文件内容
  15. >: source ~/.bash_profile
  16. 7)虚拟环境默认根目录:~/.virtualenvs

 

  1. 1)前往用户根目录
  2. >: cd ~
  3.  
  4. 2)下载nginx1.13.7
  5. >: wget http://nginx.org/download/nginx-1.13.7.tar.gz
  6. 3)解压安装包
  7. >: tar -xf nginx-1.13.7.tar.gz
  8. 4)进入目标文件
  9. >: cd nginx-1.13.7
  10.  
  11. 5)配置安装路径:/usr/local/nginx
  12. >: ./configure --prefix=/usr/local/nginx
  13. 6)编译并安装
  14. >: make && sudo make install
  15. 7)建立软连接:终端命令 nginx
  16. >: ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx
  17. 8)删除安装包与文件:
  18. >: cd ~
  19. >: rm -rf nginx-1.13.7
  20. >: rm -rf nginx-1.13.7.tar.xz
  21. 9)测试Nginx环境,服务器运行nginx,本地访问服务器ip
  22. >: nginx
  23. >: 服务器绑定的域名 ip:80

 

  1. 1)启动
  2. >: nginx
  3. 2)关闭nginx
  4. >: nginx -s stop
  5. 3)重启nginx
  6. >: nginx -s reload
  7. 4)查看端口,强行关闭
  8. >: ps -aux|grep nginx
  9. >: kill <pid:进程编号>

 

  1. base_url: 'http://101.132.27.14:8000', // 真实环境:django项目就是跑在8000端口上的
  1. """
  2. # 本地终端操作
  3. 1)本地项目打包,前往luffycity项目目录下
  4. >: cnpm run build
  5. 2)本地终端上传
  6. >: scp -r dist root@101.132.27.14:~
  7. # 开始服务器连接,在服务器终端操作
  8. 3)移动并重命名 如果/home路径先有文件,先清空在移动
  9. mv ~/dist /home/html
  10. 4)去向Nginx配置目录,备份配置,完全更新配置:填入下方内容
  11. >: cd /usr/local/nginx/conf
  12. >: mv nginx.conf nginx.conf.bak
  13. >: vim nginx.conf
  14. >: i
  15. events {
  16. worker_connections 1024;
  17. }
  18. http {
  19. include mime.types;
  20. default_type application/octet-stream;
  21. sendfile on;
  22. server {
  23. listen 80; # 监听80
  24. server_name 127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
  25. charset utf-8;
  26. location / {
  27. root /home/html; # html访问路径
  28. index index.html; # html文件名称
  29. try_files $uri $uri/ /index.html; # 解决单页面应用刷新404问题
  30. }
  31. }
  32. }
  33. 5)退出
  34. >: esc
  35. >: :wq
  36. 6)重启nginx
  37. >: nginx -s reload
  38. """

 

  1. # 关闭测试环境
  2. DEBUG = False
  3. ALLOWED_HOSTS = [
  4. '101.132.27.14' # 公网ip地址
  5. ]
  6. CORS_ORIGIN_ALLOW_ALL = True # 允许所有跨域
  7.  
  8.  
  9. # 静态文件配置:上线后还有额外配置,见下方 后台样式问题
  10. STATIC_URL = '/static/'
  11.  
  12.  
  13. # 后台http根路径
  14. # BASE_URL = 'http://127.0.0.1:8000'
  15. BASE_URL = 'http://101.132.27.14:8000'
  16. # 前台http根路径
  17. # LUFFY_URL = 'http://127.0.0.1:8080'
  18. LUFFY_URL = 'http://101.132.27.14:80'
  19. # 订单支付成功的后台异步回调接口
  20. NOTIFY_URL = BASE_URL + '/order/success/'
  21. # 订单支付成功的前台同步回调接口
  22. RETURN_URL = LUFFY_URL + '/order/pay/success/'
  23. REST_FRAMEWORK = {
  24. # 渲染模块
  25. 'DEFAULT_RENDERER_CLASSES': [
  26. 'rest_framework.renderers.JSONRenderer',
  27. # 'rest_framework.renderers.BrowsableAPIRenderer', # 去除浏览器解析
  28. ],
  29. # ...
  30. }
  1. # 需要做上线修改的内容
  2. os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'luffyapi.settings.prod')
  1. 1)进入本地项目根目录
  2. >: cd 项目根目录
  3. 2)本地导出项目环境
  4. >: pip3 freeze > packages.txt
  5. 3)如果环境中有特殊的安装包,需要处理一下xadmin
  6. packages.txt中的
  7. xadmin==2.0.1
  8. 要被替换为
  9. https://codeload.github.com/sshwsfc/xadmin/zip/django2
  1. 1)去向本地项目仓库
  2. >: cd 项目根目录
  3. 2)本地版本库操作
  4. >: git status
  5. >: git add .
  6. >: git commit -m '项目2.0上线'
  7.  
  8. 3)提交到远程版本库
  9. >: git pull origin master
  10. >: git push origin master

 

  1. 1)创建存放后台项目的目录
  2. >: mkdir /home/project
  3. 2)进入后台项目管理目录同步git仓库中的项目
  4. >: cd /home/project
  5. >: git clone https://gitee.com/ludingchao/luffapi.git
  1. 1)创建线上luffy项目虚拟环境
  2. >: mkvirtualenv luffy
  3. >: workon luffy
  4. 2)安装所需环境,在packages.txt所在目录下安装执行packages.txt文件
  5. >: pip install uwsgi
  6. >: pip install -r /home/project/luffyapi/packages.txt
  1. """
  2. 1)进行uwsgi服务配置,内容如下
  3. >: vim /home/project/luffyapi/luffyapi.xml
  4. <uwsgi>
  5. <socket>127.0.0.1:8808</socket> <!-- 内部端口,自定义 -->
  6. <chdir>/home/project/luffyapi/</chdir> <!-- 项目路径 -->
  7. <module>luffyapi.wsgi</module> <!-- luffyapi为wsgi.py所在目录名-->
  8. <processes>4</processes> <!-- 进程数 -->
  9. <daemonize>uwsgi.log</daemonize> <!-- 日志文件 -->
  10. </uwsgi>
  11. 4)去向Nginx配置目录,备份配置,完全更新配置:填入下方内容
  12. >: vim /usr/local/nginx/conf/nginx.conf
  13. events {
  14. worker_connections 1024;
  15. }
  16. http {
  17. include mime.types;
  18. default_type application/octet-stream;
  19. sendfile on;
  20. server {
  21. listen 80;
  22. server_name 127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
  23. charset utf-8;
  24. location / {
  25. root /home/html; # html访问路径
  26. index index.html; # html文件名称
  27. try_files $uri $uri/ /index.html; # 解决单页面应用刷新404问题
  28. }
  29. }
  30. # 新增的server
  31. server {
  32. listen 8000;
  33. server_name 127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
  34. charset utf-8;
  35. location / {
  36. include uwsgi_params;
  37. uwsgi_pass 127.0.0.1:8808; # 端口要和uwsgi里配置的一样
  38. uwsgi_param UWSGI_SCRIPT luffyapi.wsgi; #wsgi.py所在的目录名+.wsgi
  39. uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 项目路径
  40. }
  41. }
  42. }
  43. """
  1. 1)管理员连接数据库
  2. >: mysql -uroot -pOwen1234?
  3. 2)创建数据库
  4. >: create database luffy default charset=utf8;
  5. 3)设置权限账号密码:账号密码要与项目中配置的一致
  6. >: grant all privileges on luffy.* to 'luffy'@'%' identified by 'Luffy123?';
  7. >: grant all privileges on luffy.* to 'luffy'@'localhost' identified by 'Luffy123?';
  8. >: flush privileges;
  9. 4)退出mysql
  10. >: quit;
  1. # 必须在luffy环境下
  2. 1)数据库迁移
  3. >: cd /home/project/luffyapi/
  4. >: python manage_prod.py migrate
  5. 2)创建超级用户
  6. >: python manage_prod.py createsuperuser
  7. # 账号密码:admin|Admin123
  1. 1)修改base.py源码
  2. >: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/base.py
  3. 方案:3637行注释掉
  4. 2)修改operations.py源码
  5. >: vim /root/.virtualenvs/luffy/lib/python3.6/site-packages/django/db/backends/mysql/operations.py
  6. 方案:146行添加
  7. query = query.encode()
  1. """
  2. 1)启动uwsgi
  3. >: uwsgi -x /home/project/luffyapi/luffyapi.xml
  4. 2)重启nginx
  5. >: nginx -s reload
  6. """
  1. 1)编辑线上配置文件
  2. >: vim /home/project/luffyapi/luffyapi/settings/prod.py
  3. 2)修改static配置,新增STATIC_ROOTSTATICFILES_DIRS
  4. STATIC_URL = '/static/'
  5. STATIC_ROOT = '/home/project/luffyapi/luffyapi/static'
  6. STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),)
  7. 3)退出编辑
  8. >: esc
  9. >: :wq
  1. 1)项目目录下没有 static 文件夹需要新建
  2. >: mkdir /home/project/luffyapi/luffyapi/static
  3. 2)完成静态文件迁移
  4. >: python /home/project/luffyapi/manage_prod.py collectstatic
  1. 1)修改nginx配置
  2. >: vim /usr/local/nginx/conf/nginx.conf
  3. events {
  4. worker_connections 1024;
  5. }
  6. http {
  7. include mime.types;
  8. default_type application/octet-stream;
  9. sendfile on;
  10. server {
  11. listen 80;
  12. server_name 127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
  13. charset utf-8;
  14. location / {
  15. root /home/html; # html访问路径
  16. index index.html; # html文件名称
  17. try_files $uri $uri/ /index.html; # 解决单页面应用刷新404问题
  18. }
  19. }
  20. server {
  21. listen 8000;
  22. server_name 127.0.0.1; # 改为自己的域名,没域名修改为127.0.0.1:80
  23. charset utf-8;
  24. location / {
  25. include uwsgi_params;
  26. uwsgi_pass 127.0.0.1:8808; # 端口要和uwsgi里配置的一样
  27. uwsgi_param UWSGI_SCRIPT luffyapi.wsgi; #wsgi.py所在的目录名+.wsgi
  28. uwsgi_param UWSGI_CHDIR /home/project/luffyapi/; # 项目路径
  29. }
  30. # 新增的配置静态文件
  31. location /static {
  32. alias /home/project/luffyapi/luffyapi/static;
  33. }
  34. }
  35. }
  36. 2)退出
  37. >: esc
  38. >: :wq
  1. 1)关闭 uwsgi,重新启动 uwsgi
  2. >: pkill -f uwsgi -9
  3. >: uwsgi -x /home/project/luffyapi/luffyapi.xml
  4. 2)关闭 nginx,重新启动 nginx
  5. >: nginx -s stop
  6. >: nginx

 

  1. 1)本地浏览器访问xadmin后台
  2. http://101.132.27.14:8000/xadmin
  3. 2)登录,录入测试数据
  4. # 账号密码:admin|Admin123
  5.  
  6. 3)或是导出本地数据库为sql,再在线上导入sql
  7. >: mysql -h 101.132.27.14 -P 3306 -u luffy -p
  8. >: Luffy123?
  9. >: use luffy
  10. >: 复制之前的数据备份
  1. # 1、真实环境和虚拟环境都要安装uwsgi,将真实环境下的uwsgi建立软连接
  2.  
  3. # 2、redis服务一定要后台启动:redis-server &
  4.  
  5. # 3、uwsgi启动django项目一定要进入虚拟环境下,因为环境都是安装在虚拟环境中
  6.  
  7. # 4、服务器的日志都会被记录在于uwsgi配置文件 luffyapi.xml 同类目下的 uwsgi.log 中

 

celery在服务器上启动:
1)打开终端连接服务器
2)cd到项目所在目录,也就是大luffyapi
3)启动celery,不需要-P eventlet,但是要在最后加上&,代表后台启动
4)按ctrl + c退出,再去启动beat命令就行,同样带&,再ctrl + c退出

 

版权声明:本文为ludingchao原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/ludingchao/p/12457785.html