lsoci mysql_flask项目从sqlite3升级的mysql数据库

flask项目因为需求变更,需要迁移到mysql数据库。

项目计划采用docker来管理,采用mysql官网的docker来管理。

删除数据库目录。

sudo rm -rf data/

删除原日志目录。

$ rm -rf log/

修改docker-compose.yml 文件。

从原来一个项目中复制过来的docker-compose.yml文件,内容如下:

estimate:

# restart: always

build: ./app

ports:

- "8000:8000"

links:

- mysql:mysql

volumes:

- ./app:/usr/src/app

env_file: .env

mysql:

# restart: always

image: mysql:latest

env_file: .env

ports:

- "3306:3306"

volumes:

- ./data:/var/lib/mysql

- ./data/my.cnf:/etc/mysql/my.cnf

environment:

- MYSQL_ROOT_PASSWORD=estimate

配置文件改好了,准备构建镜像:

docker-compose build

看起来一切顺利。

ERROR: for mysql oci runtime error: rootfs_linux.go:53: mounting "/var/lib/docker/aufs/mnt/258ac98827bf738a0196693883820ebb3e4801320a2a3542a39076edf9ef1649/etc/mysql/my.cnf" to rootfs "/var/lib/docker/aufs/mnt/258ac98827bf738a0196693883820ebb3e4801320a2a3542a39076edf9ef1649" caused "not a directory"

Traceback (most recent call last):

File "/usr/local/bin/docker-compose", line 9, in

load_entry_point('docker-compose==1.7.1', 'console_scripts', 'docker-compose')()

File "/usr/local/lib/python2.7/dist-packages/compose/cli/main.py", line 63, in main

log.error(e.msg)

AttributeError: 'ProjectError' object has no attribute 'msg'

看起来情况不太妙,原因来配置不能正常拉起来,貌似my.cnf不是一个目录的原因,改为映射/etc/mysql试了一下,mysql是初始化成功了,但是容器与映射目录中均没有my.cnf文件,暂不知道原因,先去掉对my.cnf的映射,再次尝试:

$ docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

6112bf03d615 estimate_estimate "/usr/local/bin/super" 29 seconds ago Up 28 seconds 5000/tcp, 0.0.0.0:8000->8000/tcp estimate_estimate_1

5bed08089c16 mysql:latest "docker-entrypoint.sh" 30 seconds ago Up 29 seconds 0.0.0.0:3306->3306/tcp estimate_mysql_1

现在看起来正常多了。

4. 修改mysql的默认字符集为utf8,修改配置文件,mysql要注意不后字符集不对,后面很麻烦。

$ docker exec -it 5bed08089c16 /bin/bash

root@5bed08089c16:/# cd /etc/

root@5bed08089c16:/etc# ll

bash: ll: command not found

root@5bed08089c16:/etc# cd mysql

root@5bed08089c16:/etc/mysql# ll

bash: ll: command not found

root@5bed08089c16:/etc/mysql# ls

conf.dmy.cnf

root@5bed08089c16:/etc/mysql# vim my.cnf

bash: vim: command not found

root@5bed08089c16:/etc/mysql# vi my.cnf

bash: vi: command not found

root@5bed08089c16:/etc/mysql#

郁闷了,容器中没有vim,连vi也没有,还好有apt安装吧。。。。

root@5bed08089c16:/etc/mysql# apt-get install vim

Reading package lists... Done

Building dependency tree

Reading state information... Done

E: Unable to locate package vim

root@5bed08089c16:/etc/mysql#

什么情况,貌似,源也不正常。。。

apt-get update

apt-get install vim

不是国内源,比较慢,等的时间有点长。。。终于好了。

连接mysql查看字符集设置情况。

root@5bed08089c16:/etc/mysql# mysql -u root -p

Enter password:

Welcome to the MySQL monitor. Commands end with ; or \g.

Your MySQL connection id is 2

Server version: 5.7.13 MySQL Community Server (GPL)

Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its

affiliates. Other names may be trademarks of their respective

owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> show variables like '%character%';

+--------------------------+----------------------------+

| Variable_name | Value |

+--------------------------+----------------------------+

| character_set_client | latin1 |

| character_set_connection | latin1 |

| character_set_database | latin1 |

| character_set_filesystem | binary |

| character_set_results | latin1 |

| character_set_server | latin1 |

| character_set_system | utf8 |

| character_sets_dir | /usr/share/mysql/charsets/ |

+--------------------------+----------------------------+

8 rows in set (0.00 sec)

准备修改字符集配置

[client]

port = 3306

socket = /var/run/mysqld/mysqld.sock

default-character-set=utf8 //added by janl

[mysqld_safe]

pid-file = /var/run/mysqld/mysqld.pid

socket = /var/run/mysqld/mysqld.sock

nice = 0

[mysqld]

skip-host-cache

skip-name-resolve

user = mysql

pid-file = /var/run/mysqld/mysqld.pid

socket = /var/run/mysqld/mysqld.sock

character_set_server=utf8 // added by janl

init_connect='SET NAMES utf8' //added by janl

port = 3306

basedir = /usr

datadir = /var/lib/mysql

tmpdir = /tmp

lc-messages-dir = /usr/share/mysql

explicit_defaults_for_timestamp

好了,让容器重启一下,让配置生效。

再次查看mysql 的字符集配置

mysql> show variables like '%character%';

+--------------------------+----------------------------+

| Variable_name | Value |

+--------------------------+----------------------------+

| character_set_client | utf8 |

| character_set_connection | utf8 |

| character_set_database | utf8 |

| character_set_filesystem | binary |

| character_set_results | utf8 |

| character_set_server | utf8 |

| character_set_system | utf8 |

| character_sets_dir | /usr/share/mysql/charsets/ |

+--------------------------+----------------------------+

8 rows in set (0.01 sec)

看来字符集都改过来了,一切顺利,创建数据库。

创建数据库

mysql> CREATE DATABASE IF NOT EXISTS estimate DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

Query OK, 1 row affected (0.00 sec)

mysql> show databases;

+--------------------+

| Database |

+--------------------+

| information_schema |

| estimate |

| mysql |

| performance_schema |

| sys |

+--------------------+

5 rows in set (0.00 sec)

mysql> use estimate;

Database changed

mysql> show tables;

Empty set (0.00 sec)

mysql>

数据库建立起来了,然后就可以和数据库一起愉快的玩耍了。。。。。。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flask 是一款 Python Web 开发框架,它非常轻量级,灵活易用,适合小型的 Web 应用程序开发。在这里,我们将会介绍如何进行一个 Flask 项目的实战开发。 ## 环境搭建 在开始之前,我们需要先安装 Flask 框架。可以使用 pip 工具来安装,打开命令行工具,输入以下命令即可: ``` pip install flask ``` ## 创建项目 接下来,我们需要创建一个 Flask 项目,可以按照以下步骤进行操作: 1. 创建一个项目文件夹,例如 flask_project。 2. 在项目文件夹中创建一个名为 app.py 的 Python 文件。 3. 在 app.py 文件中导入 Flask 模块,并创建一个 Flask 实例。 ```python from flask import Flask app = Flask(__name__) ``` ## 路由设置 我们需要设置路由,以便我们可以通过访问特定的 URL 来触发特定的代码。我们可以使用 app.route() 装饰器来设置路由。例如: ```python @app.route('/') def index(): return 'Hello, World!' ``` 在这个例子中,我们设置了一个路由根目录 /,当用户访问这个 URL 时,会调用 index 函数,并返回一个字符串 'Hello, World!'。 ## 模板引擎 在 Flask 中,我们可以使用模板引擎来渲染 HTML 页面。最常用的模板引擎是 Jinja2。我们需要在项目中创建一个 templates 文件夹,然后在 app.py 文件中设置 Jinja2 模板引擎。 ```python from flask import Flask, render_template app = Flask(__name__) @app.route('/') def index(): return render_template('index.html') ``` 在这个例子中,我们设置了路由根目录 /,当用户访问这个 URL 时,会调用 index 函数,并渲染一个名为 index.html 的模板文件。 ## 数据库连接 在 Flask 中,我们可以使用多种数据存储方式,包括 MySQL、PostgreSQL、SQLite 等。这里以 SQLite 为例进行说明。我们需要在项目中创建一个名为 database.db 的 SQLite 数据库文件,并使用 SQLite3 模块进行连接。 ```python import sqlite3 conn = sqlite3.connect('database.db') ``` ## 表单处理 在 Web 应用程序中,表单是非常重要的组成部分。Flask 提供了 Flask-WTF 扩展来处理表单。我们需要使用 pip 工具安装 Flask-WTF 扩展。 ``` pip install flask-wtf ``` 然后在 app.py 文件中导入 Flask-WTF 扩展,并创建一个表单类。 ```python from flask_wtf import FlaskForm from wtforms import StringField, SubmitField from wtforms.validators import DataRequired class NameForm(FlaskForm): name = StringField('Name', validators=[DataRequired()]) submit = SubmitField('Submit') ``` 在这个例子中,我们创建了一个名为 NameForm 的表单类,包含一个名为 name 的字符串字段和一个名为 submit 的提交按钮。 ## 部署项目 在开发完成之后,我们需要将项目部署到服务器上。最常用的 Web 服务器是 Apache 和 Nginx。Flask 也提供了一个名为 Werkzeug 的开发 Web 服务器,但它只适用于开发环境。在生产环境中,我们需要使用 Apache 或 Nginx。 ## 总结 这就是一个 Flask 项目的基本开发流程。当然,在实际开发中,还有很多其他的问题需要处理,例如用户验证、数据存储等。希望这篇文章能够帮助你入门 Flask 开发。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值