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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏pangguoming

(十一) 整合spring cloud云架构 - SSO单点登录之OAuth2.0登录流程(2)

上一篇是站在巨人的肩膀上去研究OAuth2.0,也是为了快速帮助大家认识OAuth2.0,闲话少说,我根据框架中OAuth2.0的使用总结,画了一个简单的流程图...

18620
来自专栏代码散人

Vapor奇幻之旅(08 连接服务端MongoDB)

首先付上官网的安装教程:安装mongodb,这个是社区版,由于企业版是收费的,就先来个社区版以供测试使用。

9330
来自专栏睿哥杂货铺

Linux 性能诊断:负载评估

从load avgerage等总括性的数据着手,参考CPU使用率和I/O等待时间等具体的数字,从而自顶向下快速排查各进程状态。

315100
来自专栏美团技术团队

LsLoader——通用移动端Web App离线化方案

背景 由于JavaScript(以下简称JS)语言的特性,前端作用域拆分一直是前端开发中的首要关卡。从简单的全局变量分配,到RequireJS实现的AMD模块方...

480170
来自专栏前端大白专栏

React Native: Possible unhandled promise rejection request fail

64760
来自专栏代码散人

Vapor奇幻之旅(02部署)

在Vapor奇幻之旅(01开篇) 中我介绍了如何用swift来构建web应用,这篇文章我会介绍如何在ubuntu服务器上部署vapor项目。

16630
来自专栏数据和云

MySQL DBA之路 | 性能配置调优篇

一、简介 数据库服务器需要CPU、内存、 磁盘和网络才能运行,了解这些资源对于DBA来说非常重要,因为任何的超载行为都可能成为限制因素,导致数据库服务器性能不佳...

48960
来自专栏腾讯开源的专栏

看看“疫苗查询”小程序有温度的代码

16530
来自专栏帘卷西风的专栏

关于cocos2dx程序的BUG调试解决方案

      今天说一下手机游戏开发的调试问题吧。不得不说的是和PC平台游戏、软件开发相比,手机上开发游戏和软件要困难的多。原因是多方面的,比如说开发环境比较复杂...

10620
来自专栏杨建荣的学习笔记

MySQL审计插件使用和对比

数据库审计是数据库安全中很重要的一个环节,说到审计,有些上市公司内部还会根据塞班斯法案,进行404审计等等。 而最基本的审计还是需要的,有些同学可能...

86290

扫码关注云+社区

领取腾讯云代金券