Swift后端Vapor安装数据库

MySQL

亲,我的简书已不再维护和更新了,所有文章都迁移到了我的个人博客:https://mikefighting.github.io/,欢迎交流。

Vapor中使用Fluent作为数据库的驱动,它现在可支持的数据库类型有:MySQL,SQL lite,MongoDB,PostgreSQL。因为MySQL用得较多,我们先来学习它。

安装过程

安装MySQL-Provider

Package.swift文件中加入

.Package(url: "https://github.com/vapor/mysql-provider.git", majorVersion: 2)

然后执行执行vapor cleanrm -rf .build Package.pins,最后执行vapor updatevapor build
安装完MySql之后报错mysql/mysql.h file not found以及Could not build Objective-C module CMySQL,这时因为MySql数据库需要更新,执行下面的指令

brew update && brew install mysql vapor/tap/cmysql pkg-config

然后再执行vapor xcode就可以运行成功了。

配置

在Droplet中添加驱动

我们要往Config对象中添加相应的Provider,如下所示

import MySQLProvider
let config = try Config()
try config.addProvider(MySQLProvider.Provider.self)
let drop = try Droplet(config)

配置Fluent

fluent.json文件中加入如下的配置

{
    "//": "The underlying database technology to use.",
    "//": "memory: SQLite in-memory DB.",
    "//": "sqlite: Persisted SQLite DB (configure with sqlite.json)",
    "//": "Other drivers are available through Vapor providers",
    "//": "https://github.com/search?q=topic:vapor-provider+topic:database",
    "driver": "mysql",
}

配置MySQL

在Config文件夹下面新建文件mysql.json,并添加如下内容

{
    "hostname": "localhost",
    "user": "root",
    "password": "yourPassword",
    "database": "yourDatabase"
    "poort": "3306"
}      

也可以将证书作为url传入MySQL。

{
"url": "http://root:password@172.0.0.1/hello"
}

多份读取(Read Replicas)

多份读取可以通过配置hostname或者是readReplicas接口数组来进行配置。在mysql.josn中加入:

    {
       {
        "master": "master.mysql.foo.com",
        "readReplicas": ["read01.mysql.foo.com", "read02.mysql.foo.com"],
        "user": "root",
        "password": "password",
        "database": "hello"
       }
    }

Tip:也可以将readReplicas用字符串表示,多个字符串用逗号分隔开。

驱动

你可以在Routes中得到MySQL Driver(前提是在你自己的MySQL数据库中创建了your_table)表。

 import MySQLProvider
 get("mysql") { req in
            
            let mysqlDriver = try self.mysql()
            let user = try mysqlDriver.raw("SELECT * FROM your_table")
            let reusltJon = try JSON(node: user)
            return reusltJon
            
        }

然后在浏览器中输入http://localhost:8080/mysql,如果看到输出了相应的JSON传就证明安装成功了。

配置缓存

Config/droplet.json里面可以配置fluent缓存,这里fluent缓存走的是mysql

{
 "driver": "fluent"
}

下次,当启动Droplet的时候,如果出现:

Database prepared

就说明安装成功了。

帮助

1. 如果运行出现

The current hash key "0000000000000000" is not secure.
Update hash.key in Config/crypto.json before using in production.
Use `openssl rand -base64 <length>` to generate a random string.
The current cipher key "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=" is not secure.
Update cipher.key in Config/crypto.json before using in production.
Use `openssl rand -base64 32` to generate a random string.

这说明我们需要运行openssl rand -base64 <length>,以及openssl rand -base64 32来产生新的hash key和cipher key,并且将原来的数值替换掉。

2. MySql更改密码:

  1. 执行 sudo mysqld_safe --skip-grant-tables,然后输入电脑的密码
  2. 新建一个终端窗口
  3. 执行:mysql -u root,这时可以不用密码直接登录
  4. 执行: use mysql,然后就可以使用sql语句了
  5. 执行describe user;(注意有结尾的分号),就可以看到user表了
  6. 修改authentication_string字段:update user set authentication_string=password('password') where user='root';
  7. 退出mysql,执行quit
  8. 重新登录mysql -u root -p,这时输入密码即可。

请参考:

  1. https://stackoverflow.com/questions/2101694/mysql-how-to-set-root-password-to-null
  2. https://stackoverflow.com/questions/30692812/mysql-user-db-does-not-have-password-columns-installing-mysql-on-osx
  3. https://sraji.wordpress.com/2011/08/10/how-to-reset-mysql-root-password/
  4. https://stackoverflow.com/questions/9624774/after-mysql-install-via-brew-i-get-the-error-the-server-quit-without-updating
  5. https://stackoverflow.com/questions/9624774/after-mysql-install-via-brew-i-get-the-error-the-server-quit-without-updating/9704993#comment16367803_9704993

需要注意的是:sudo mysqld_safe --skip-grant-tables执行完之后,要重新打开一个终端执行

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

推荐阅读更多精彩内容