手把手教你在centos上配置Django项目(超详细步骤)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 手把手教你在centos上配置Django项目(超详细步骤)

小白学Django系列:


前言

关于Django的部署,本人也踩了很多坑,这篇文章一步一步教你怎么进行部署,只需要你按照我的步骤来就OK了!这里我们使用的服务器是一个全新的服务器,没有安装任何东西。


基础环境搭建步骤

★ 注意:下面的步骤都需要在root权限下进行


一、更新系统软件包


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


三、下载Pyhton3到/usr/local 目录


cd /usr/local


wget https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tgz


★ 这里我们安装的Python是3.6.6版本,版本可以自己选择,如果版本不同,后面相应的代码也会不同!!!

解压python包


tar -zxvf Python-3.6.6.tgz


进入 Python包的路径


cd Python-3.6.6


编译安装到自己指定路径-/usr/local/python3


./configure --prefix=/usr/local/python3


安装python3


make
make install


安装完成之后,建立软链接,添加变量,这样的好处是方便我们在终端中能够直接使用python3


ln -s /usr/local/python3/bin/python3.6 /usr/bin/python3


Python3安装完成之后pip3也一块安装完成,不用再单独安装 这里给pip3也建立软链接


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


四、查看是否成功安装Python3和pip3


python3 -V
pip3 -V


60.jpg


如图则成功


五、安装virtualenv

★ 建议大家都安装一个virtualenv,方便不同版本项目管理。虚拟环境这块大家可以自行百度进行了解,当然也可以直接按照我下面的步骤进行


pip3 install virtualenv


我们也给它建立软链接


ln -s /usr/local/python3/bin/virtualenv /usr/bin/virtualenv


安装成功在根目录下建立文件夹,主要用于存放env,当然项目你也可以创建一个文件夹存放。我的项目是存放在/~/blog中的,影响不大,后面自己可以进行相关修改(我会注明)


mkdir -p /data/env


六、切换到/data/env/下,创建虚拟环境。


virtualenv --python=/usr/bin/python3 djangoenv


这里的djangoenv名称可以自己定义但是后面步骤一定要跟你所定义的名称相同,然后进入/data/env/djangoenv/bin

启动虚拟环境:


source activate


进入之后,你就会发现下面红框中的内容就是自己定义的名称


61.jpg


七、虚拟环境里用pip3安django和uwsgi


pip3 install django (需要指定安装和你项目相同的版本)
pip3 install uwsgi


★ uwsgi要安装两次,一次在虚拟环境中,另一次退出虚拟环境进行安装

给uwsgi建立软链接


ln -s /usr/local/python3/bin/uwsgi /usr/bin/uwsgi


本地Django项目部署到服务器

上面的步骤已经将整个大致的环境安装好了,接下来我们就需要把自己本地的项目搬运上来。


一、备份本地数据库。使用Mysql数据库,要先在本地Mysql里备份导出数据,然后在服务器上安装Mysql数据库

关于在centos中安装Mysql,我会在下篇文章中写,敬请关注(里面的坑比较多,我都会总结好的)


二、在项目目录下把当前的环境依赖包导出到requirements.txt文件


pip freeze > requirements.txt


★ 注意:这里是在自己本地上进行的,导出你整个项目需要的依赖包


三、把项目源码压缩打包。


四、把项目上传到服务器对应的目录里,解压。

这里我使用的是Fileziila软件进行上传的,大家可以自己去下载相关的ftp软件,把自己项目上传到服务器。

在服务器中解压,可以先安装支持ZIP的工具


yum install -y unzip zip


解压zip文件


unzip 文件名.zip


五、创建新的虚拟环境(参照上面基础环境步骤中的第六步)

六、进入虚拟环境,然后进入项目安装目录requirements.txt里的依赖包。


pip3 install -r requirements.txt


七、导入数据库到服务器。(Mysql)

关于数据库的导入步骤:


# 进入数据库
mysql -u root -p
# 创建与项目中相应的名称的数据库
create database kulsblog;
use kulsblog
source /你导入sql文件的目录地址


八、通过python3 manage.py runserver 运行一下项目,如果能正常启动则进行下一步,不能正常运行往上检查。

这里需要注意使用python3来执行manage.py,否则会出现报错情况!


九.配置uwsgi文件(重点!!!)

我的网站项目路径是/root/blog/kuls_blog,在项目根目录下创建 项目名称.xml (例如我的就是 kuls_blog.xml) 编辑该文件:


<uwsgi>
   <socket>127.0.0.1:8000</socket><!-- 内部端口,自定义 -->
   <chdir>/root/blog/kuls_blog</chdir><!-- 项目路径 -->
   <module>kuls_blog.wsgi</module><!-- mysite为wsgi.py所在目录名-->
   <processes>4</processes><!-- 进程数 -->
   <daemonize>uwsgi.log</daemonize><!-- 日志文件 -->
</uwsgi>


★ 注意里的kuls_blog,这个是wsgi.py所在的目录名。大家记得仔细看我的注释进行填写!!!


十、安装nginx和配置nginx.conf文件

进入home目录,执行下面命令,我这里安装的是1.13.7版本。


cd /home/


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,把原来的内容删除,直接加入以下内容:


events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    server {
        listen 80;
        server_name  127.0.0.1:80; #改为自己的域名,没域名修改为127.0.0.1:80
        charset utf-8;
        location / {
           include uwsgi_params;
           uwsgi_pass 127.0.0.1:8000;  #端口要和uwsgi里配置的一样
           uwsgi_param UWSGI_SCRIPT kuls_blog.wsgi;  #wsgi.py所在的目录名+.wsgi
           uwsgi_param UWSGI_CHDIR /root/blog/kuls_blog; #项目路径
        }
        location /static/ {
        alias /root/blog/kuls_blog/static/; #静态资源路径
        }
    }
}


大家一定仔细看每个参数后面的注释,这里容易出错!!!这里的参数一定要和之前配置的xml文件相对应

进入/usr/local/nginx/sbin/目录 执行 ./nginx -t 命令先检查配置文件是否有错,没有错就执行以下命令:


./nginx


终端没有任何提示就证明nginx启动成功。

★ uwsgi和Nginx两个配置,在整个部署里面是非常非常重要的,如果出现报错,一定往上面翻一翻,看看有没有哪个步骤出现问题。


重点

如果修改了Django文件或者一些其他的配置,一定要重启uwsgi和Nginx,否则不会生效!


#查看Uwsgi进程
ps -ef|grep uwsgi
#用kill方法把uwsgi进程杀死,然后启动uwsgi
killall -9 uwsgi
#启动方法
uwsgi -x mysite.xml
#Nginx平滑重启方法
/usr/local/nginx/sbin/nginx -s reload


上面是重启uswgi和Nginx的步骤,大家每次修改之后,调用上面的方法即可。


一些注意事项

如果你的项目中的应用含有静态文件,你需要在setting.py中进行STATIC_ROOT的设置


STATIC_ROOT  = os.path.join(BASE_DIR, 'static')#指定样式收集目录
#或
STATIC_ROOT = '/www/mysite/kuls_blog/static'  #指定样式收集目录


并且执行下面的指令:


python manage.py collectstatic


运行这个命令之后,就会自动把静态文件收集到/static/目录下。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
3月前
|
关系型数据库 MySQL 数据库连接
Django数据库配置避坑指南:从初始化到生产环境的实战优化
本文介绍了Django数据库配置与初始化实战,涵盖MySQL等主流数据库的配置方法及常见问题处理。内容包括数据库连接设置、驱动安装、配置检查、数据表生成、初始数据导入导出,并提供真实项目部署场景的操作步骤与示例代码,适用于开发、测试及生产环境搭建。
127 1
|
2月前
|
缓存 NoSQL Linux
在CentOS 7系统中彻底移除MongoDB数据库的步骤
以上步骤完成后,MongoDB应该会从您的CentOS 7系统中被彻底移除。在执行上述操作前,请确保已经备份好所有重要数据以防丢失。这些步骤操作需要一些基本的Linux系统管理知识,若您对某一步骤不是非常清楚,请先进行必要的学习或咨询专业人士。在执行系统级操作时,推荐在实施前创建系统快照或备份,以便在出现问题时能够恢复到原先的状态。
254 79
|
29天前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
130 10
|
2月前
|
存储 前端开发 应用服务中间件
Django 实战:静态文件与媒体文件从开发配置到生产部署
Django项目中,静态文件(Static Files)和媒体文件(Media Files)是两类不同用途的文件。本文详细介绍了它们的区别、配置方法以及在开发与生产环境中的处理方式,并结合用户头像上传功能进行实战演示,最后讲解了如何通过Nginx或OpenResty部署静态与媒体文件服务。
119 1
|
4月前
|
关系型数据库 MySQL Linux
CentOS系统安装phpStudy的详细步骤和注意事项
一、安装流程 执行官方安装脚本 通过以下命令直接安装官方集成环境(支持CentOS 7及以上版本): ``` yum install -y wget && wget -O install.sh https://www.hsbang.com/ install.sh && sh install.sh ``` 安装过程包含自动下载组件和配置环境,需等待2-5分钟。
232 4
|
5月前
|
关系型数据库 MySQL Linux
CentOS 7系统下详细安装MySQL 5.7的步骤:包括密码配置、字符集配置、远程连接配置
以上就是在CentOS 7系统下安装MySQL 5.7的详细步骤。希望这个指南能帮助你顺利完成安装。
1408 26
|
8月前
|
数据管理 数据库 数据安全/隐私保护
Django—同一项目不同app使用不同数据库
在Django项目中实现不同app使用不同数据库的配置,可以通过配置多数据库、创建数据库路由和配置路由来实现。通过这种方法,可以有效地将数据隔离到不同的数据库,提高数据管理的灵活性和系统的可扩展性。希望本文能为开发者在Django项目中使用多数据库提供清晰的指导。
168 4
|
10月前
|
存储 监控 Linux
在 CentOS 7 中如何对未分配的大容量硬盘进行分区和挂载。通过具体案例,详细说明了使用 `fdisk` 创建分区、格式化分区、创建挂载点以及临时和永久挂载分区的步骤
本文介绍了在 CentOS 7 中如何对未分配的大容量硬盘进行分区和挂载。通过具体案例,详细说明了使用 `fdisk` 创建分区、格式化分区、创建挂载点以及临时和永久挂载分区的步骤。此外,还分享了一些实践经验,帮助读者更好地管理和优化磁盘空间。
796 8
|
10月前
|
存储 监控 Linux
在 CentOS 7 中进行磁盘分区和挂载的具体操作步骤,如何使用 `fdisk` 创建分区、格式化分区、创建挂载点以及临时和永久挂载分区的方法。
本文介绍了在 CentOS 7 中进行磁盘分区和挂载的具体操作步骤。通过一个实际案例,详细说明了如何使用 `fdisk` 创建分区、格式化分区、创建挂载点以及临时和永久挂载分区的方法。此外,还分享了一些实践经验,帮助读者更好地管理和优化服务器磁盘空间。
1752 4
|
10月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
521 3