免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 6306 | 回复: 3
打印 上一主题 下一主题

[其他] golang 如何连 mysql 不要每次建立一个连接 [复制链接]

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-06-07 17:46 |显示全部楼层 |倒序浏览
本帖最后由 zylthinking 于 2017-06-07 17:48 编辑

@cokeboL, 有没有趟过这个坑?
mysql 自己认最大链接 150,
现在是设置了
       db.SetMaxOpenConns(10);
        db.SetMaxIdleConns(10);


不起作用;
stmt.Close() 也调用了
row.Close() 也调用了

就是不起作用;
一次调用创建一个新连接, 150次准挂

我就不明白了, 这还有救吗



func db_get() (*sql.DB, error) {
    if (db != nil) {
        return db, nil;
    }

    mux.Lock();
    if (db != nil) {
        mux.Unlock();
        return db, nil;
    }

    conf := setting.Conf;
    if (conf == nil) {
        mux.Unlock();
        return nil, errors.New("can't get mysql configuration");
    }

    var buf bytes.Buffer;
    buf.WriteString(conf.Mysql.User);
    buf.WriteByte(':');
    buf.WriteString(conf.Mysql.Passwd);
    buf.WriteString("@tcp(");
    buf.WriteString(conf.Mysql.Addr);
    buf.WriteString(")/db?charset=utf8");
    db, err := sql.Open("mysql", buf.String());
    if (err == nil) {
       db.SetMaxOpenConns(10);
        db.SetMaxIdleConns(10);

    }
    mux.
Unlock();
    return db, err;
}

func UserGet(email string) (*Account, error) {
    db
, err := db_get();
    if (err != nil) {
        
return nil, err;
    }

    stmt
, err := db.Prepare("select * from account where email = ?");
    if (err != nil) {
        
return nil, err;
    }
    defer stmt.Close();

    row, err:= stmt.Query(email);
    if (err != nil) {
        
return nil, err;
    }
    defer row.Close();

    obj, err := fill_row(row, &Account{});
    if (err != nil) {
        
return nil, err;
    } else if (obj == nil) {
        
return nil, nil;
    }
   
return obj.(*Account), nil;
}


论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
2 [报告]
发表于 2017-06-07 18:44 |显示全部楼层
靠, 我知道怎么会是了

db, err := sql.Open("mysql", buf.String());
这个声明了一个新的本地变量 db, 而不是全局 db 变量;导致全局 db 永远是 nil, 从而不断创建 db 对象导致的, 坑的你没话说

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
3 [报告]
发表于 2017-06-12 18:30 |显示全部楼层
回复 5# yulihua49

你都没搞清楚是怎么回事, 就开始飙常识................

论坛徽章:
11
未羊
日期:2013-12-16 12:45:4615-16赛季CBA联赛之青岛
日期:2016-04-11 19:17:4715-16赛季CBA联赛之广夏
日期:2016-04-06 16:34:012015亚冠之卡尔希纳萨夫
日期:2015-11-10 10:04:522015亚冠之大阪钢巴
日期:2015-07-30 18:29:402015亚冠之城南
日期:2015-06-15 17:56:392015亚冠之卡尔希纳萨夫
日期:2015-05-15 15:19:272015亚冠之山东鲁能
日期:2015-05-14 12:38:13金牛座
日期:2014-12-04 15:34:06子鼠
日期:2014-10-16 13:40:4715-16赛季CBA联赛之八一
日期:2016-07-22 09:41:40
4 [报告]
发表于 2017-06-28 11:28 |显示全部楼层
windoze 发表于 2017-06-26 14:23
你开几个goroutine专门处理MySQL,有数据库请求通过channel发过来给这几个goroutine处理,这样就不会爆了。


sql.DB 本来就是连接池, 之前的错误在于 golang := 语法的一个 trick 导致不断创建新的连接池导致的连接数用尽; 不在于应该不应该使用连接池
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP