Django安裝與簡單配置(1)


碼好python的每一篇文章.


大家好!又有一段時間沒更新文章了,沒錯,是真的忙了。想要寫一篇文章,確實要花幾天時間的功夫,因為要保障文章的品質。

後面的文章我會通過寫些基礎理論和實戰文章,畢竟干技術的,光看理論確實會沒那麼多耐心,總之,我會穿插一些,保證各位看官滿意為止。

1. 環境準備

序號 IP地址 作業系統 安裝軟體 備註
1 192.168.8.130 CentOS 7.6.1810 python3.6+django2.2 都運行在虛擬環境
2 192.168.8.131 CentOS 7.6.1810 mysql mysql數據
3 192.168.8.1 windows 10 PyCharm Pro 專業版能夠使用與centos遠程同步配置
  • CentOS7安裝環境,請Google 或百度查找安裝文檔,該步驟略。

  • python環境安裝

    pyenv虛擬環境管理python多版本和軟體庫 請參考此文。

    如何更新pip源步驟:

    [root@localhost ~]# mkdir .pip
    [root@localhost ~]# cd .pip/
    [root@localhost .pip]# touch pip.conf
    [root@localhost .pip]# vim pip.conf 
    [global]
    index-url = //mirrors.aliyun.com/pypi/simple/
    [install]
    trusted-host=mirrors.aliyun.com
    # 添加或修改後,記得保存。
    

如何更新YUM源步驟:

  # 安裝wget,有則忽略,跳過
  [root@localhost ~]# yum install wget -y
  
  # 備份yum源
  [root@localhost python]# cd /etc/yum.repos.d/
  [root@localhost yum.repos.d]# mkdir repo_bak
  [root@localhost yum.repos.d]# mv *.repo repo_bak/
  
  # 下載新的repo
  [root@localhost yum.repos.d]# wget //mirrors.aliyun.com/repo/Centos-7.repo
  
  # 清除系統yum快取並生成新的yum快取
  [root@localhost yum.repos.d]# yum clean all
  [root@localhost yum.repos.d]# yum makecache
  
  # 安裝EPEL(Extra Packages for Enterprise Linux )源
  [root@localhost yum.repos.d]# yum install -y epel-release
  
  # 再次清除系統yum快取並生成新的yum快取
  [root@localhost yum.repos.d]# yum clean all
  [root@localhost yum.repos.d]# yum makecache
  
  # 查看系統可用的yum源和所有的yum源
  [root@localhost yum.repos.d]# yum repolist enabled

PIP源更新參考鏈接

YUM源更新參考鏈接

2. 開始安裝

2.1 安裝Django

說明: 此台CentOS IP地址是 192.168.8.130(通過NAT映射,可以上互聯網)

# 安裝django2.2版本
(py369) [python@localhost Python]$ pip install django==2.2

# 查看已安裝的版本資訊
(py369) [python@localhost Python]$ python -m django --version
2.2

# 安裝mysql拓展
(py369) [python@localhost Python]$ pip install mysqlclient

2.2 安裝 Mysql資料庫

說明: 此台CentOS IP地址是 192.168.8.131(通過NAT映射,可以上互聯網)

# 安裝mysql及拓展
[root@localhost ~]# wget -i -c //dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
[root@localhost ~]# yum -y install mysql57-community-release-el7-10.noarch.rpm
[root@localhost ~]# yum -y install mysql-community-server-5.7.31-1.el7.x86_64.rpm

# 啟動mysql服務
[root@localhost ~]# systemctl start mysqld.service

# 查看mysql服務狀態
[root@localhost ~]# systemctl status mysqld.service
   ...此處省略字元
   # active 就表示正常在運行了
   Active: active (running) since Tue 2020-07-21 10:14:23 CST; 2s ago
   ...此處省略字元

  • 修改密碼及創建資料庫
# 查找密碼,uQjeSi?N(2zH,這個就是預設密碼
[root@localhost ~]# grep "password" /var/log/mysqld.log
2020-07-21T20:48:28.965616Z 1 [Note] A temporary password is generated for root@localhost: uQjeSi?N(2zH

# 用預設密碼登陸資料庫
[root@localhost ~]# mysql -uroot -p
Enter password:uQjeSi?N(2zH  # 輸入密碼

# 修改密碼
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'DevOps@2020';
Query OK, 0 rows affected (0.01 sec)
# 授權訪問資料庫
mysql> grant all on *.* to 'root'@'%' identified by 'DevOps@2020';
Query OK, 0 rows affected, 1 warning (0.00 sec)
# 刷新許可權
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

# 創建新的資料庫
mysql> CREATE DATABASE IF NOT EXISTS devops default charset utf8 COLLATE utf8_general_ci;
Query OK, 1 row affected (0.00 sec)

# 查看已創建的資料庫
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| devops             |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)


# 退出資料庫,修改配置文件,結果如下所示:
[root@localhost ~]# cat /etc/my.cnf |grep -v ^#|grep -v ^$
[client]
default-character-set = utf8
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
symbolic-links=0
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
character-set-server = utf8
collation-server = utf8_general_ci

# 重啟資料庫
[root@localhost ~]# service mysqld restart
  • 資料庫連接驗證正常:

    windows 10下安裝mysql拓展並驗證連接資料庫:

C:\>pip install mysqlclient

備註: 我是通過pycharm導入模組pymysql進行測試。

3. 開始配置

各位先簡單意淫下這種圖,應該有個初步的認識。

  • 當一位屌絲打開瀏覽器訪問某頁面的時候,輸入//www.baidu.com,然後回車;

  • django後台urls就會匹配到鏈接,可以把urls看作是http鏈接,專業叫做路由;

    說明:不是我們攻城獅理解的路由協議哈。

  • urls匹配到了就會在View視圖查找程式碼,然後做出響應;

    說明:view就是我們要寫的python程式碼

  • template簡單理解就是html頁面模板;

  • Model簡單理解資料庫的一張表;

3.1 Django簡單配置

3.1.1 創建一個工程(project)為devops:

# 先安裝個tree軟體包
[python@localhost ~]$ sudo yum install tree

# 創建一個新的工程project
(py369) [python@localhost Python]$ django-admin startproject devops

(py369) [python@localhost Python]$ tree devops
devops
├── devops
│   ├── __init__.py
│   ├── __pycache__
│   │   ├── __init__.cpython-36.pyc
│   │   ├── settings.cpython-36.pyc
│   │   ├── urls.cpython-36.pyc
│   │   └── wsgi.cpython-36.pyc
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── manage.py


3.1.2 通過PyCharm遠程同步伺服器程式碼

說明: pycharm將django項目下載到window電腦上進行編輯,然後再實時同步到CentOS上,pycharm編寫程式碼方便。

  1. 打開pycharm,點擊Tools->Deployment->Configuration

  1. 創建新的服務名,參考如下配置:

3)下載遠端django的project:

4)修改自動同步配置,Tools->Deployment->Options

3.1.3 在pycharm上直接修改django的配置文件:

1)devops->devops->settings.py:

# 允許所有主機訪問django,星號表示所有主機
ALLOWED_HOSTS = ['*']

# 增加資料庫資訊
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME':'devops',
        'HOST':'192.168.8.131',
        'USER':'root',
        'PASSWORD':'root@123',
        'PORT':3306,
    }
}

#修改語言編碼和時區
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'

2) 改完配置後,會自動同步到遠程django那裡。
摘取log部分:

2020/3/27 23:07] Automatic upload completed in 33 ms: 1 file transferred (103.6 kbit/s)

3.1.4 啟動django服務

1)通過命令啟動:python manage.py runserver 0.0.0.0:8888

(py369) [python@localhost devops]$ python manage.py runserver 0.0.0.0:8888
Watching for file changes with StatReloader
Performing system checks...

System check identified no issues (0 silenced).
March 27, 2020 - 23:45:14
Django version 2.2, using settings 'devops.settings'
Starting development server at //0.0.0.0:8888/
Quit the server with CONTROL-C.

2)打開瀏覽器,輸入//192.168.8.130:8888

3)還可以進入後台許可權管理系統,輸入//192.168.8.130:8888/admin

此時,還沒有創建超級管理員用戶和密碼,不能夠登陸。

4)接下來啟動自帶的APP admin

(py369) [python@localhost devops]$ python manage.py migrate

備註:此命令會把系統自帶的admin app資料庫寫入到mysql中。

5)登陸資料庫mariadb,看是否正常寫入

[root@localhost ~]# mysql -u root -pDevOps@2020

# 查看資料庫
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| ddjsdb             |
| devops             |
| devops01           |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
7 rows in set (0.73 sec)

# 切換到資料庫devops中
mysql> use devops  

# 查看資料庫devops中的表,已經成功寫入了
mysql> show tables;
+----------------------------+
| Tables_in_devops           |
+----------------------------+
| auth_group                 |
| auth_group_permissions     |
| auth_permission            |
| auth_user                  |
| auth_user_groups           |
| auth_user_user_permissions |
| django_admin_log           |
| django_content_type        |
| django_migrations          |
| django_session             |
+----------------------------+
10 rows in set (0.00 sec)

6)創建一個管理員用戶

(py369) [python@localhost devops]$ python manage.py createcachetable
# 依次輸入用戶名、郵箱地址、密碼

7)成功登陸後台管理系統

# 再次啟動django
(py369) [python@localhost devops]$ python manage.py runserver 0.0.0.0:8888

3.2 創建新的APP

3.2.1 創建新的app hello

(py369) [python@localhost devops]$ python manage.py startapp hello

# 手工創建urls.py 文件
(py369) [python@localhost devops]$ touch hello/urls.py

# 查看app hello 樹結構
(py369) [python@localhost devops]$ tree hello
hello
├── admin.py
├── apps.py
├── __init__.py
├── migrations
│   └── __init__.py
├── models.py
├── tests.py
├── urls.py
└── views.py

3.2.2 pycharm同步下載遠程hello目錄

說明:方法同章節3.1.2一樣。

3.2.3 修改django配置腳本

1) 修改devops->devops->setting.py配置

INSTALLED_APPS = [
	...此處已省略
    'hello.apps.HelloConfig',     # 方式一:新增hello app資訊
    'hello',                      # 方式二:新增hello app資訊
]

2) 修改devops->hello->views.py配置

from django.shortcuts import render
from django.http import HttpResponse


def index(request):
    return HttpResponse('<p>hello django</p>')

3) 修改devops->hello->urls.py配置

from django.urls import path
from . import views

urlpatterns = [
    path('hello/', views.index, name='index'),
]

4)最後修改devops->devops->urls.py配置

說明: 此urls.py為根路由入口(即總入口)。

第一種靜態路由urls演示方法:

from hello import views
urlpatterns = [
    path('admin/', admin.site.urls),  # 預設
    path('hello/', views.index),      # 新增
]

登陸瀏覽器,輸入//192.168.8.130:8888/hello/,效果如下:

第二種靜態路由urls演示方法:

from django.urls import path,include  # 新增,導入include模組
urlpatterns = [
    path('admin/', admin.site.urls),  # 預設
    path('hello/', include('hello.urls')),  # 新增
]

登陸瀏覽器,輸入//192.168.8.130:8888/hello/hello,效果如下:


如果喜歡的我的文章,歡迎關注我的公眾號:點滴技術,掃碼關注,不定期分享

公眾號:點滴技術