百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

Django项目部署到服务器(django项目怎么部署到服务器)

toyiye 2024-04-04 11:41 20 浏览 0 评论

1. 安装python3.8

1.1 安装相关依赖包

yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel libffi-devel

项目python版本为3.8.5, django版本为3.1.1

1.2 下载并解压python3.8.5

yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel libffi-devel

1.3 编译安装

cd Python-3.8.5/./configure --prefix=/usr/local/python3makemake install

1.4 创建软链接

ln -s /usr/local/python3/bin/python3.8 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3.8 /usr/bin/pip3

2. 安装项目相关库

2.1 项目中所使用的库可以导出到文本文件中

# 从开发环境中导出所安装的库到requirements.txt文件中

pip freeze > requirements.txt

2.2 在服务器中安装requirements.txt中的库

pip install -r requirements.txt

2.3 安装uwsgi

pip install uwsgi

3. 安装mysql

3.1 下载

wget http://tel.mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.34-el7-x86_64.tar.gz

3.2 拷贝安装包到/usr/local/目录下,并解压

# 重命名压缩包

mv mysql-5.7.34-el7-x86_64.tar.gz mysql.tar.gztar zxf mysql.tar.gz
# 进入mysql目录
cd mysql

3.3 创建data目录

cd mysqlmkdir data

3.4 创建mysql用户并设置权限

useradd mysql -s /sbin/nologin -M
# 回到/usr/local目录cd ..
# 设置mysql目录权限
chown -R mysql.mysql mysql

3.5 初始化数据库

cd mysql
# 执行后,屏幕会提示root临时密码,需要记录下来
bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
  • 这一步可能会发生错误

bin/mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory

  • 解决
yum install libaio

3.6 编辑my.cnf文件


wget https://www.python.org/ftp/python/3.8.5/Python-3.8.5.tgztar zvxf Python-3.8.5.tgz

3.7 创建error.log

cd Python-3.8.5/./configure --prefix=/usr/local/python3makemake install

3.8 拷贝启动文件到/etc/init.d目录

ln -s /usr/local/python3/bin/python3.8 /usr/bin/python3
ln -s /usr/local/python3/bin/pip3.8 /usr/bin/pip3

3.8.1 修改启动文件中的路径

# vim /etc/init.d/mysqld
# 修改basedir和datadir
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data

3.9 启动mysql

/etc/init.d/mysqld start

3.10 创建软链接

ln -s /usr/local/mysql/mysql.sock /tmp/mysql.sock

3.11 使用临时密码登录数据库并重新为root设置密码

cd /usr/local/mysql
# 回车后会提示输入密码,输入临时密码回车即可
bin/mysql -uroot -p

# 登录之后修改密码
mysql> set password = password('123456');
mysql> alter user 'root'@'localhost' password expire never;
mysql> flush privileges;

4. 安装nginx

4.1 下载

wget http://nginx.org/download/nginx-1.17.7.tar.gz

4.2 安装相关依赖包

yum install -y pcre pcre-devel openssl openssl-devel gcc

4.3 创建nginx用户

useradd nginx -s /sbin/nologin -M

4.4 安装nginx

tar zxf nginx-1.17.7.tar.gz
cd nginx-1.17.7
./configure --user=nginx --group=nginx --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
make && make install

5. 安装redis

5.1 安装

wget http://download.redis.io/releases/redis-2.8.17.tar.gz
tar xzf redis-2.8.17.tar.gz
mv redis-2.8.17 redis
cd redis
make 

5.2 启动

cd src
./redis.server

cd src
./redis.server

6. uwsgi配置

# 在项目根目录下创建uwsgi.ini文件

[uwsgi]
# 配置nginx连接的socket连接 /data/web/project为项目目录
socket=/data/web/project/project.sock
# 配置uwsgi.pid所在的目录
pidfile=/data/web/project/uwsgi.pid
# 进程数
processes=8
# 每个进程的线程数
threads=2
# 项目路径,项目所在的目录
chdir=/data/web/project
# wsgi接口模块文件路径
module=project.wsgi
# 启动管理主进程
master=true
enable-threads=true
logdate=true
limit-as=6048
# 日志文件
daemonize=/data/web/project/run.log

6.1 启动

# -d表示后台启动
uwsgi -d --ini uwsgi.ini

6.2 相关操作

# 停止
uwsgi --stop uwsgi.pid
# 重启
uwsgi --reload uwsgi.pid

7. 配置nginx

7.1 nginx.conf

#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
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;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
include vhost/*.conf;
}

7.2 创建vhost目录

mkdir vhost
cd vhost

7.3 项目配置文件

# vim www.xxx.com.conf
server {
    listen 80;
    server_name www.xxx.com;
    charset utf-8;
    client_max_body_size 50M;
  
    location / {
        uwsgi_pass unix:/data/web/project/project.sock;
        include uwsgi_params;
    }
  
    location /static {
       alias /data/web/project/static;
    }
  
    location /media {
      alias /data/web/project/media;
    }
}

8. 关于css, js 丢失问题

代码迁移至服务器前,使用命令 python manage.py collectstatic 收集静态文件

python manage.py collectstatic

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码