之前生成选型python3,除了用的python3的pymysql模块之外其他的都是一样的。

1、首先搭建mysql(Mariadb)数据库(单点)
        安装方式分为yum安装,rpm包安装和源码安装,单点测试并且完全裸机建议yum直接安装或者。如果高可用(配合mycat)建议首选rpm包安装。其他的建议源码安装。
        1.1、yum安装(确定有正确的yum源 https://mirrors.tuna.tsinghua.edu.cn/)
                 yum  install  mariadb*
                 systemctl  enable mariadb
                 systemctl  start  mariadb
                 添加mysql的root密码
                                   use mysql set password=PASSWORD('password') where User='root';
                                   设置其他主机登录的权限:
                 mysql>GRANT   ALL   PRIVILEGES   ON   *.*   TO   'root'@'%'   WITH   GRANT   OPTION  //赋予任何主机访问数据的权限

mysql>FLUSH   PRIVILEGES  //修改生效

                
        1.2、rpm包安装(步骤转自我朋友王康宁的笔记https://www.kancloud.cn/ningjing_home/ceph/462330
                卸载系统自动安装的mariadb

          yum -y remove MariaDB*
            安装mysql的rpm包,需按照以下顺序进行安装。

            rpm -ivh mysql-community-common-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-libs-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-client-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-server-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-devel-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-embedded-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-libs-compat-5.7.17-1.el7.x86_64.rpm            rpm -ivh mysql-community-embedded-devel-5.7.17-1.el7.x86_64.rpm    
             初始化mysql数据库,获取登录密码

           mysqld --initialize --user=mysql
                       若提示目录下有文件,直接将/var/lib/mysql/ 文件夹下的文件删除干净再次执行。
                       

                       完成后 进入日志文件查找初始化生成的密码vi /var/log/mysqld.log
                       

启动mysql
           systemctl start mysqld

修改初始密码
                       登录mysql
                       mysql -u root -p
                       输入日志中的密码
                       第一次更改密码前所有的操作都是禁止的,依次执行:
           set password=password('123456');flush privileges; quit;
                       或者通过命令行
           mysqladmin -u root -p"5NUV1wX<;pj=" password 123456
                重启mysql:
           systemctl restart mysqld
                 查看配置文件:
           cat /etc/my.cnf

    1.3 源码安装

           wget http://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz
                           安装启动:
                           gunzip mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz
                           mv mysql-5.7.17-linux-glibc2.5-x86_64.tar /usr/local/
                          .创建运行MySQL的用户和组(名字可以任意)
                           Shell> groupadd mysql
                           Shell> useradd mysql -g mysql

切换到mysql目录

Shell > mkdir data

修改解压包的权限

Shell> chown –R mysql .

Shell> chgrp –R mysql .

安装MySQL

Shell> bin/mysqld --initialize --user=mysql --datadir=/usr/local/mysql/data ##初始化数据目录

shell> cp -f support-files/my-default.cnf /etc/my.cnf ##将默认配置文件复制到指定目录

shell> bin/mysqld_safe --datadir=/usr/local/mysql/data --user=mysql & ##启动MySQL服务

shell> cp support-files/mysql.server /etc/init.d/mysql.server ##将MySQL加入到服务自启动

Shell> /etc/init.d/mysql.server start ##通过服务启动MySQL

MySQL配置文件my.ini中,在[mysqld]下添加skip-grant-tables,关闭mysql服务并重新开启;                                输入命令:mysql -u root -p
                            回车后,要求输入密码,直接回车跳过,则直接进入MySQL。
                            这样设置之后,可以直接双击D:\MySQL5.7.10\bin下的mysql.exe启动,而不用输入命令。
                            update mysql.user set password=PASSWORD('password') where User='root';

2、安装python的相关模块(注意顺序)

2.1、安装python-devel,mysql-devel(其中含有mysql_config模块)

2.2、在pypi.org下载MySQL-python-1.2.5.zip包。

2.3、源码安装MySQL-python,python setup.py install

[root@VirtualBox-web MySQL-python-1.2.5]# python  -c  "import  MySQLdb"

/usr/lib64/python2.7/site-packages/MySQL_python-1.2.5-py2.7-linux-x86_64.egg/_mysql.py:3: UserWarning: Module _mysql was already imported from /usr/lib64/python2.7/site-packages/MySQL_python-1.2.5-py2.7-linux-x86_64.egg/_mysql.pyc, but /root/MySQL-python-1.2.5 is                being added to sys.path

因为是源码安装会有两个MySQL_python-1.2.5-py2.7-linux-x86_64.egg,检查版本一致的话,手动将root下的MySQL_python-1.2.5-py2.7-linux-x86_64.egg删除。

3、修改项目的链接mysql。

DATABASES = {

                          'default': {
                             'ENGINE': 'django.db.backends.mysql',
                             'NAME': 'lagou',
                             'USER': 'root',
                             'PASSWORD': 'password',
                             'HOST': '127.0.0.1',
                             'PORT': '3306',
                            }
                           }

4、测试Django对mysql的连通性。

4.1、django.db.utils.OperationalError: (2003, "Can't connect to MySQL server on '192.168.56.104' (113)"),

Django链接不到外网,修改项目setting.py的 ALLOWED_HOSTS = []成ALLOWED_HOSTS = ['*',]

4.2、django.db.utils.OperationalError: (1130, "Host '192.168.56.105' is not allowed to connect to this MariaDB server")

mysql>GRANT   ALL   PRIVILEGES   ON   *.*   TO   'root'@'%'   WITH   GRANT   OPTION  //赋予任何主机访问数据的权限

mysql>FLUSH   PRIVILEGES  //修改生效

4.3、  python manage.py migrate,自动创建web系统使用的表

               
       4.4、通过Django创建指定表huiFangFirstTable和huiFangSecondTable。
                  
         4.5、查看创建的sql
                  
             4.6创建表成功
                
 

搭建Django链接MySQL流程(python2版)的更多相关文章

  1. Django 链接MySQL及数据操作

    Django 链接MySQL Django创建的项目自带的数据库是SQLite3,我们想要链接MySQL的话,需要更改settings.py中的配置 1.在MySQL中创建好数据库,Django项目不 ...

  2. Django链接MySQL,数据库迁移

    form表单默认是以get请求提交数据的 http://127.0.0.1:8000/login/?username=admin&password=123 action 1 不写,默认向当前地 ...

  3. Django—链接MySQL

    Djalgo基础配置方法 静态文件配置方法 1 所有的静态文件都放在 static 文件夹下,例如Bootstrap值类的第三方库,通常 static 文件下会创建 css image js 文件,用 ...

  4. Django链接Mysql 8.0 出现错误(1045:Access denied for user 'root'@'localhost' (using password: NO) 的一种解决方法

    运行环境: Django版本2.0 ; Mysql 版本 8.0.11; 错误代码:  django.db.utils.OperationalError: (1045:Access denied fo ...

  5. Django 链接mysql

    第一步:settings.py DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'testdjango ...

  6. Django链接mysql数据库报错1064

    D:\PycharmProjects\autotest>python manage.py makemigrations django.db.utils.ProgrammingError: (10 ...

  7. django——django链接mysql数据库

    1.创建项目 django-admin startproject django_mysql 2.创建App python manage.py startapp app1 3.Mysql数据库配置 (1 ...

  8. HttpResponse,render,redirect,静态文件配置,request对象方法,pycharm连接MySQL,django连接MySQL,django ORM

    HttpResponse 主要用于返回字符串类型的数据 def index(request): return HttpResponse('index页面') 在页面中就会显示 index页面 rend ...

  9. 第一篇:Win10系统搭建Python+Django+Nginx+MySQL 开发环境详解(完美版)

    Win10+Python+Django+Nginx+MySQL 开发环境搭建详解 PaulTsao 说明:本文由作者原创,仅供内部参考学习与交流,转载引用请注明出处,用于商业目的请联系作者本人. Wi ...

随机推荐

  1. Privoxy代理的使用

    目录 1. Privoxy介绍 1.1 安装 1.2 配置 1.3 使用 1.4 其他配置 1.5 测试链接及查看配置 2. 相关信息 https://www.privoxy.org/ http:// ...

  2. 由strcat函数引发的C语言中数组和指针问题的思考

    问题一 首先,来看一下下面这段代码: #include <stdio.h> #include <string.h> int main() { char *str = " ...

  3. java项目---用java实现二叉平衡树(AVL树)并打印结果(详)(3星)

    package Demo; public class AVLtree { private Node root; //首先定义根节点 private static class Node{ //定义Nod ...

  4. Python的内置方法——补充

    七 __setitem__,__getitem__,__delitem__ class Foo: def __init__(self,name): self.name=name def __getit ...

  5. What is the Annotation?

    Annotation称为注释或注解,它是一个接口.注解提供了一种为程序元素(类.方法.成员变量等)设置元数据(描述其它数据的数据)的方法.编译器.开发工具或其它程序中可以通过反射来获取程序中的Anno ...

  6. linx6.7 update openssh to 7.7p1

    升级之前需要注意几点: 1 必须要有自己的镜像,必须自己做好本地yum源(可以连接外网,能够有网络yum源也可以) 2 配置好基本的升级环境.在升级openssh时需要依赖openssl和zlib.一 ...

  7. ST&倍增LCA

    回顾st算法,它的一大功能是求区间最值.先将整个区间划分成若干个小的区间,求出最值,然后将小的区间合并成一个大的区间,我们这里要用到一个数组minn[i][j],划重点!如果我们要求的是区间最小值,m ...

  8. OpenJ_Bailian 4148 生理周期

    生理周期 OpenJ_Bailian - 4148 Time limit1000 ms Memory limit65536 kB OS Linux SourceEast Central North A ...

  9. getOrCreateEnvironment()方法源码探究

    该方法目的是创建一个环境对象,并且根据环境类型,自动判断是创建web环境对象,还是标准非web环境对象. 首先该方法源于prepareEnvironment准备环境: 然后进入该方法源码: 可以发现: ...

  10. linux dd命令 创造一个文件

    创造一个1G的文件 dd if=/dev/zero of=/nod/tmp/test bs=1M count=1024 创造一个1T的文件 [root@oracledg tmp]# dd if=/de ...