Vapor奇幻之旅(09 连接MySQL)

这一篇文章主要介绍如何在Vapor项目中连接mysql数据库。MySQL相信是大家最常用的数据库之一了,几乎每个公司都有用到这个数据库,如果你对于数据库的选择相对保守,那么mysql是个不错的选择。

在前几篇中我介绍了PostgreSQL和MongoDB的连接:

Vapor奇幻之旅(05 Fluent)
Vapor奇幻之旅(06 PostgreSQL)
Vapor奇幻之旅(07 连接服务端PostgreSQL)
Vapor奇幻之旅(08 连接服务端MongoDB)

如果你看了前几篇,应该知道连接数据库遵循以下套路:

1、安装配置好服务器,并提供外部访问的端口和权限。
2、添加相应的数据库的provider,provider会提供连接数据库的driver和对数据库的相关操作的支持。
3、项目里配置provider,并提供数据库的主机、用户名、密码、端口等信息。
4、测试连接。

本篇也将按照这个顺序介绍如何连接MySQL数据库。

1、安装配置MySQL

这一篇我还是介绍如何在ubuntu16.04上安装MySQL:

安装命令:

$ sudo apt-get update
$ sudo apt-get install mysql-server
$ mysql_secure_installation

第三个命令是安全相关的,根据自己的需要配置密码强度等信息。

安装好之后测试登陆一下:

$ mysql -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.7.21-0ubuntu0.16.04.1 (Ubuntu)

Copyright (c) 2000, 2018, 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.

接着运行

$ netstat -ntpl

可以看到mysql已经在运行,且使用的是3306接口:


image.png

但是本地ip地址是127.0.0.1,表示只能本地访问,于是需要修改/etc/mysql/mysql.conf.d/mysqld.cnf配置文件:

$ vim /etc/mysql/mysql.conf.d/mysqld.cnf

如果安装的是mysql5.6或者更低的版本,配置文件在 /etc/mysql/my.cnf这个文件里

$ vim /etc/mysql/my.cnf

修改里面的

bind-address        = 0.0.0.0

修改完保存退出,重启mysql服务

$ sudo service mysql restart

在运行

$ netstat -ntpl

可以看到本地ip已经变成0.0.0.0了


image.png

这时到阿里控制台安全组添加3306接口的入方向授权,如果用的其他服务器,也需要添加允许端口访问的规则。

到这里我们的服务端的mysql就装好了。

2、配置MySQLProvider

在运行项目前,和PostgreSQLProvider需要CPostgreSQL库一样,MySQLProvider也需要为系统安装CMySQL库,这样项目才能够被成功编译:
MacOS:

brew install vapor/tap/cmysql

Ubuntu:

sudo apt-get install cmysql
  • 1、配置Package.swift
// swift-tools-version:4.0

import PackageDescription

let package = Package(
    name: "VaporMySQL",
    products: [
        .library(name: "App", targets: ["App"]),
        .executable(name: "Run", targets: ["Run"])
    ],
    dependencies: [
        .package(url: "https://github.com/vapor/vapor.git", .upToNextMajor(from: "2.1.0")),
        .package(url: "https://github.com/vapor/fluent-provider.git", .upToNextMajor(from: "1.3.0")),
        .package(url: "https://github.com/vapor/mysql-provider", .upToNextMajor(from: "2.0.0"))
    ],
    targets: [
        .target(
            name: "App",
            dependencies: ["Vapor",  "FluentProvider", "MySQLProvider"],
            exclude: ["Config", "Database", "Localization", "Public", "Resources"]
        ),
        .target(name: "Run", dependencies: ["App"]),
        .testTarget(name: "AppTests", dependencies: ["App", "Testing"])
    ]
)

接着生成xcode项目

$ vapor xcode

对于已有的项目进行更新即可

$ vapor update
  • 2、、在Config+Setup.swift中添加provider
import FluentProvider
import MySQLProvider

...

/// Configure providers
    private func setupProviders() throws {
        try addProvider(FluentProvider.Provider.self)
        try addProvider(MySQLProvider.Provider.self)
    }

3、添加Config/mysql.json文件,并配置内容:

{
    "hostname": "xxx.xxx.xxx.xxx",
    "user": "root",
    "password": "*******",
    "database": "mysql"
}

4、运行程序,测试接口。
将targert设置为run,运行设备选择My Mac,如果选择了连接Mac的iphone,会报错的。

执行插入操作:

image.png

执行查询操作:


image.png

3、Trouble Shooting

  • 无法连接上服务器
    1、服务端运行netstat -ntpl 查看是否mysql本地ip是0.0.0.0,否则修改mysql的配置文件中的bind-address为0.0.0.0并重启mysql服务
    2、检查是否添加安全组,如阿里云的安全组规则,添加3306接口的访问权限
    3、进入服务端的mysql数据库,查询用户权限:
mysql> select host, user from user;
+-----------+------------------+
| host      | user             |
+-----------+------------------+
| %         | root             |
| localhost | debian-sys-maint |
| localhost | mysql.session    |
| localhost | mysql.sys        |
+-----------+------------------+
4 rows in set (0.00 sec)

如果host不是%可以通过以下方式来修改

mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> update user set host = '%' where user = 'root';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> flush privileges
    -> ;
Query OK, 0 rows affected (0.00 sec)

上面的root可以换成其他的user名
4、检查防火墙设置

  • 本地提示缺少CMySQL库,需要按照上文中的方式添加CMySQL库到系统,如果生成项目后再从系统添加库支持,则需要vapor update一下项目,重新生成一个xcodeproj文件,这样就可以编译通过了。

总结

本篇介绍了怎么在ubuntu系统上安装和配置MySQL, 如何配置远程访问服务端的MySQL数据库,如果使用项目连接MySQL数据库。

关于Vapor其他知识,可以参考以下文章:

Vapor奇幻之旅(01开始)
Vapor奇幻之旅(02部署)
Vapor奇幻之旅(03上手)
Vapor奇幻之旅(04Routing)
Vapor奇幻之旅(05 Fluent)
Vapor奇幻之旅(06 PostgreSQL)
Vapor奇幻之旅(07 连接服务端PostgreSQL)
Vapor奇幻之旅(08 连接服务端MongoDB)

希望你对我的教程能够喜欢,你们的赞是我持续的动力,欢迎加入QQ群参与互动:431296189

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容

  • 在配置ubuntu16.4服务器上的postgresql数据库时遇到了很多问题,网上查了很多资料,都没有太深的理解...
    leacode阅读 970评论 0 0
  • 在Vapor奇幻之旅(02部署)一篇中,我介绍了如何在ubuntu上部署并运行vapor项目,这篇文章我来讲讲怎么...
    leacode阅读 1,227评论 0 0
  • 本篇介绍如何用vapor连接另一种数据库Mongodb 安装MongoDB 首先付上官网的安装教程:安装mongo...
    leacode阅读 909评论 0 1
  • 用Vapor连接数据库是一件令人兴奋的事,本篇就来介绍如何使用Vapor来连接PostgreSQL数据库,将数据持...
    leacode阅读 925评论 0 0
  • 【壹】 我是一个流浪的说书人,为了生计也算上那么几卦。这两者在我眼里并无不同,都是在讲述别人的故事,仅此而已我喜欢...
    岳如悬阅读 597评论 3 1