Django_1

云服务器配置docker&git

django:

Django是后起之秀,近些年越来越流行,Youtube(月活20亿+)、Instagram(月活10亿+)等公司采用了Django框架。
可以作为Web、App、小程序、AcWing云端App(AC APP)等各种项目的后端。

开发效率高,生态完善,有官方社区长期支持 运行效率高
项目运行效率瓶颈有很多,比如:数据库查询、网络带宽/延迟、硬盘读写速度等,这些与框架关系不大。
计算密集型的模块可以用C/C++实现,然后编译成动态链接库再import进来。
计算密集型的微服务可以通过thrift等工具对接,微服务的Server端代码可以用C/C++语言实现。
有很多工具可以将Python代码翻译成C/C++,比如Cython、Pypy、AcWing

项目开发:

前后端分离的好处:一个后端支持多种前端。
数据库分为两大类:Mysql 和 Redis,Redis是内存数据库,在内存中存储map。
项目中存储数据的层 (server端) :Redis(内存)>Mysql(存代码、文本、题解、账户分值信息)>云盘(硬盘,存视频和图片)
项目中存储数据的层 (client端): Web sotrage 浏览器缓存 (刷新页面不会消失)、 js内存 (刷新页面会消失)
websocket协议:是一个允许两端都可以发送消息的通信协议。其在用户端和服务端建立一个长连接。

开发环境:

在这里插入图片描述
完全无需配置本地环境。利用AC Terminal直接在云端开发,使用工具:vim、tmux等。不推荐在本地开发
本项目会涉及多台服务器间的网络通信,如果在本地开发,未来不方便调试和部署。
在本地开发无法统一开发环境,部分python包在windows系统上安装困难。
需要租一台具有公网IP的云服务器,并安装docker。
服务器配置无要求
后期可以利用docker随意迁移
在AC Terminal的/var/lib/acwing/docker/images/目录下给大家提供统一的课程docker镜像。
标准化开发环境,避免未来出现软件版本不兼容。
省去配环境的环节。
使用AC Git管理项目代码。
方便回滚代码

配置docker、git环境

scp /var/lib/acwing/docker/images/ django_lesson_1_0.tar server_name: # 将镜像上传到自己租的云端服务器
ssh server_name # 登录自己的云端服务器
docker load -i django_lesson_1_0.tar # 将镜像加载到本地
docker run -p 20000:22 -p 8000:8000 --name django_server -itd django_lesson:1.0 # 创建并运行django_lesson:1.0镜像 (端口要自己去云平台放行)
docker attach django_server # 进入创建的docker容器
passwd # 设置root密码
adduser acs # 创建普通用户acs
usermod -aG sudo acs # 给用户acs分配sudo权限
su -acs# 可切换到用户acs中
ctrl p + ctrl q #挂起容器
返回AC terminal,为acs用户配置别名和免密登录
vim config # 配置别名
ssh-copy-id 别名 # 为acs用户一键添加公钥,免密登录,需要在开始就生成了公钥,不然在这里失败,ssh-keygen可以生成公钥。
scp .bashrc .vimrc .tmux.conf 别名: # 配置一下环境

20000的端口号是方便登陆的,8000的端口号是方便调试;
在这里插入图片描述
在这里插入图片描述
由于用的云服务器是阿里云,默认关闭所有端口,所以还需在阿里云手动配置端口:
在这里插入图片描述
更多->网络安全组->安全配置组->配置规则->手动添加即可

项目创建

打开tumx
django-admin startproject acapp #创建django项目acapp
配置git:
ssh-keygen # 生成密钥用于连接到ac git上面
在git偏好设置中,打开ssh密钥,添加一下刚才生成的公钥
git init # 进到acapp中将其配置成git仓库
打开git,在git上创建一个仓库(项目)按照下面的提示在acs里面配置一下git
git config --global user.name xxx git config --global user.email xxx@xxx.com git add . git commit -m "xxx" git remote add origin git@git.acwing.com:xxx/XXX.git #建立连接

git push --set-upstream origin master再打开一个tmux,(一个tmux用于维护控制台,另一个tmux用于开发)跑一下我们的项目 python3 manage.py runserver 0.0.0.0:8000
ag ALLOWED-HOSTS #全文搜索
找到这个字段所在位置,并将自己的IP地址添加到里面
便可用 IP地址:8000 打开django页面
git 一下代码
注意:在git仓库的根目录下(acapp),vim .gitignore
在文件里面写上 **/__pycache__(两个杠)
再去添加文件的时候就不会再添加这类不必要的文件
python3 manage.py startapp game # 创建gameapp
登录django管理员界面
ctrl c 先关掉控制台
python3 manage.py migrate #同步一下数据库的修改
python3 manage.py createsuperuser # 创建管理员账号
pyhton3 manage.py runserver 0.0.0.0:8000 # 启动控制台
IP地址:8000/admin # 进到管理员登录界面,输入一下刚才创建的账号即可进到管理员界面
cd game touch urls.py mkdir templates vim views # 定义一个index函数 视频位置 1:00:00
vim urls.py # 写一下路由
cd acapp vim urls.py # 将刚才的路由写到总路由里面
models:存储各种数据结构(class等)
views:存储函数
urls:路由
templates:存储网页模板
git一下代码,完工

实例

1创建django
acs@4c3dea94cf88:~$ django-admin --version
	3.2.8
acs@4c3dea94cf88:~$ django-admin startproject acapp
acs@4c3dea94cf88:~$ ls
	acapp
acs@4c3dea94cf88:~$ tree .
.
`-- acapp
    |-- acapp
    |   |-- __init__.py
    |   |-- asgi.py
    |   |-- settings.py
    |   |-- urls.py
    |   `-- wsgi.py
    `-- manage.py
2 directories, 6 files

2git维护项目
acs@4c3dea94cf88:~/acapp$ git init
	Initialized empty Git repository in /home/zxy/acapp/.git/
# git中生成ssh-key,git其实是用ssh实现的
acs@4c3dea94cf88:~/acapp$ cd 
acs@4c3dea94cf88:~$ ssh-keygen
acs@4c3dea94cf88:~/acapp$ ls -a
	.  ..  .git  acapp  manage.py
acs@4c3dea94cf88:~/acapp$ git config --global user.name "俊 李"
acs@4c3dea94cf88:~/acapp$ git config --global user.email "lj127*******@163.com"
acs@4c3dea94cf88:~/acapp$ git remote add origin git@git.acwing.com:lj127***/acapp.git
acs@4c3dea94cf88:~/acapp$ git push --set-upstream origin master

3运行项目

#0.0.0.0
acs@4c3dea94cf88:~/acapp$ python3 manage.py runserver 0.0.0.0:8000
访问IP:8000是平台

IP加入ALLOWED_HOSTS

zacs@4c3dea94cf88:~/acapp/acapp$ vim settings.py
ALLOWED_HOSTS = [“8.130.***.245”]
此时 ‘acapp/pycache/’ 中的文件是python预编译好的,用于python运行的系统代码,不需要传到git上 ;
zxy@b1986ee36b7a:~/acapp$ vim .gitignore
#写入
*/pycache/
zxy@b1986ee36b7a:~/acapp$ git commit -m “modify allowed host”
zxy@b1986ee36b7a:~/acapp$ git push

4通过app写django页面
acs@4c3dea94cf88:~$ cd acapp/
acs@4c3dea94cf88:~/acapp$ ls
README.md  acapp  db.sqlite3  manage.py
acs@4c3dea94cf88:~/acapp$ python3 manage.py startapp
usage: manage.py startapp [-h] [--template TEMPLATE]
                          [--extension EXTENSIONS] [--name FILES]
                          [--version] [-v {0,1,2,3}]
                          [--settings SETTINGS]
                          [--pythonpath PYTHONPATH] [--traceback]
                          [--no-color] [--force-color]
                          name [directory]
manage.py startapp: error: You must provide an application name.
acs@4c3dea94cf88:~/acapp$ python3 manage.py startapp game
acs@4c3dea94cf88:~/acapp$ 
acs@4c3dea94cf88:~/acapp$ ls
README.md  acapp  db.sqlite3  game  manage.py
acs@4c3dea94cf88:~/acapp$ tree.s
-bash: tree.s: command not found
acs@4c3dea94cf88:~/acapp$ tree .
.
|-- README.md
|-- acapp
|   |-- __init__.py
|   |-- __pycache__
|   |   |-- __init__.cpython-38.pyc
|   |   |-- settings.cpython-38.pyc
|   |   |-- urls.cpython-38.pyc
|   |   `-- wsgi.cpython-38.pyc
|   |-- asgi.py
|   |-- settings.py
|   |-- urls.py
|   `-- wsgi.py
|-- db.sqlite3
|-- game
|   |-- __init__.py
|   |-- admin.py #存储管理员页面里能看到哪些数据库的信息
|   |-- apps.py
|   |-- migrations
|   |   `-- __init__.py
|   |-- models.py #定义网站各种数据库中的表,即存储数据结构,例如User这样的class
|   |-- tests.py
|   `-- views.py #存视图,即函数;每点一个按钮就是调用服务器端的一个函数,这些函数在views.py里实现
`-- manage.py

4 directories, 19 files

用git维护刚刚的文件
开始git维护时出现了报错

acs@4c3dea94cf88:~/acapp$ git push
To git.acwing.com:lj1273147443/acapp.git
 ! [rejected]        master -> master (fetch first)
error: failed to push some refs to 'git@git.acwing.com:lj1273147443/acapp.git'
hint: Updates were rejected because the remote contains work that you do
hint: not have locally. This is usually caused by another repository pushing
hint: to the same ref. You may want to first integrate the remote changes
hint: (e.g., 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.

后来维护的代码:

git pull --rebase origin master
git push -u origin master
acs@4c3dea94cf88:~/acapp$ git pull --rebase origin master
remote: Enumerating objects: 7, done.
remote: Counting objects: 100% (7/7), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 4 (delta 2), reused 0 (delta 0), pack-reused 0
Unpacking objects: 100% (4/4), 416 bytes | 416.00 KiB/s, done.
From git.acwing.com:lj1273147443/acapp
 * branch            master     -> FETCH_HEAD
   0e0df72..cf5fb51  master     -> origin/master
First, rewinding head to replay your work on top of it...
Applying: modify allowed host
Using index info to reconstruct a base tree...
M       acapp/settings.py
.git/rebase-apply/patch:14: new blank line at EOF.
+
warning: 1 line adds whitespace errors.
Falling back to patching base and 3-way merge...
Applying: modify allowed host
Applying: modify allowed host
Applying: start app game
acs@4c3dea94cf88:~/acapp$ git push -u origin master
Enumerating objects: 21, done.
Counting objects: 100% (21/21), done.
Delta compression using up to 2 threads
Compressing objects: 100% (15/15), done.
Writing objects: 100% (19/19), 1.81 KiB | 1.81 MiB/s, done.
Total 19 (delta 4), reused 0 (delta 0)
To git.acwing.com:lj1273147443/acapp.git
   cf5fb51..b0ced22  master -> master
Branch 'master' set up to track remote branch 'master' from 'origin'.


# 更新数据库内容
acs@4c3dea94cf88:~/acapp$ python3 manage.py migrate
# 创建管理员账号
acs@4c3dea94cf88:~/acapp$ python3 manage.py createsuperuser

在这里插入图片描述
终端创建的时候密码可以简单,但在admit创建的时候密码会更复杂
IP:8000/admin :管理员页面
IP:8000 :django正常页面

5创建自己的页面
#django可以创建多个app,但本项目只用一个app
# 现在只是文件,当内容变多可升级为文件夹
# urls是一个路由,用户访问groups(点击)的时候,传入的是一个地址,服务器端需要知道这个地址应该调用哪个函数,因此需要路由。
acs@4c3dea94cf88:~/acapp/game$ touch urls.py 
# 存网页模板html
acs@4c3dea94cf88:~/acapp/game$ mkdir templates

views.py中实现最简单的函数
views.py传入一个链接加参数,该函数返回一个字符串(html的网页代码)

  1 from django.http import HttpResponse
  2 
  3 def index(request):
  4     return HttpResponse("李大钊的第一个网页!!!")   

在urls.py中完成
其中path是一个解析的过程,会返回一个函数

1 from django.urls import path
2 from game.views import index
3
4 urlpatterns = [                                                            
5 	path("",index, name="index"),
6 ]
表示啥都不解析,index函数,name="index"

传过来之后,如果url啥都没有,就调用index函数返回"Hello world"字符串界面

app的URL还需要写到总的URL里面,在acs@4c3dea94cf88:~/acapp/acapp$ vim urls.py
如果是game,返回game_app里的内容;

 16 from django.contrib import admin
 17 from django.urls import path, include
 18 
 19 urlpatterns = [
 20     path('game/', include('game.urls')),                                   
 21     path('admin/', admin.site.urls),
 22 ]

打开 http://8.130.51.245:8000/game/就可以打开网页了
在这里插入图片描述

6流程

用户的请求(网址)——>acapp/urls.py——>
path(’’, include(‘game.urls’)) 即game.urls——>
path(“”,index, name=“index”) 即index函数 ——>
return HttpResponse(“Hello world”)

优化

在这里插入图片描述

Django_celery_beat是一个django应用程序,它允许您使用celery定期运行周期性任务。这些周期性任务可以是一次性的或循环的,你可以设置它们在指定的时间间隔内自动运行,也可以设置它们在特定的时间运行。 要使用django_celery_beat,请按照以下步骤操作: 1. 安装django_celery_beat: ``` pip install django_celery_beat ``` 2. 在settings.py中添加以下代码: ``` INSTALLED_APPS = [ # ... 'django_celery_beat', ] CELERY_BEAT_SCHEDULER = 'django_celery_beat.schedulers:DatabaseScheduler' ``` 3. 在项目的urls.py文件中添加以下代码: ``` from django.urls import path from django_celery_beat.views import ( PeriodicTaskListView, PeriodicTaskCreateView, PeriodicTaskUpdateView, PeriodicTaskDeleteView, PeriodicTaskDetailView, ) urlpatterns = [ # ... path('celery/periodic-tasks/', PeriodicTaskListView.as_view(), name='periodic_task_list'), path('celery/periodic-task/add/', PeriodicTaskCreateView.as_view(), name='periodic_task_create'), path('celery/periodic-task/<int:pk>/', PeriodicTaskDetailView.as_view(), name='periodic_task_detail'), path('celery/periodic-task/<int:pk>/update/', PeriodicTaskUpdateView.as_view(), name='periodic_task_update'), path('celery/periodic-task/<int:pk>/delete/', PeriodicTaskDeleteView.as_view(), name='periodic_task_delete'), ] ``` 4. 在celery.py文件中添加以下代码: ``` from celery import Celery from django.conf import settings app = Celery('my_project') app.config_from_object('django.conf:settings', namespace='CELERY') app.autodiscover_tasks(lambda: settings.INSTALLED_APPS) ``` 5. 在tasks.py文件中创建您的任务,例如: ``` from celery import shared_task @shared_task def my_task(): # Do something here ``` 6. 创建周期性任务,您可以使用Django admin或创建它们的视图。 现在,您已经可以在django中使用celery定期运行周期性任务了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值