mnesia 和mysql 同步_Mnesia数据库及其集群的配置

mnesia_manage.erl模块专门用以管理本工程中用到的各种数据库。 其导出函数有: create_all_tables/0,用以创建本模块里定义的所有数据表。 create_online_users/0,创建在线用户表。 create_users/0,创建用户表 create_user_data/0,创建用户资料表 create_ava

mnesia_manage.erl模块专门用以管理本工程中用到的各种数据库。

其导出函数有:

create_all_tables/0,用以创建本模块里定义的所有数据表。

create_online_users/0,创建在线用户表。

create_users/0,创建用户表

create_user_data/0,创建用户资料表

create_available_acc/0,创建可供注册的账号表

create_reserved_acc/0,创建保留账号表

insert_formal_acc/2插入正式的账号

insert_test_acc/2,插入测试账号

select_all/1,[Tab]选择某表所有记录

tab_length/1,[Tab]查询某标的长度

使用本模块时,执行erl命令时,除了要指明节点名称等,还需要指明存放mnesia数据库的路径,命令如下:

erl -sname NodeChatCore1 -pa ./chat_server/ebin -mnesia dir '"./mnesia_dir_ChatServerCore_1"'

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611055353187%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

进入erlang shell后,执行命令:mnesia_manage:create_all_tables(). 之后退出shell,进入mnesia_dir_ChatServerCore_1文件夹,即可看到刚刚建立的各个数据库的文件。

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611055037562%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

再次进入节点NodeChatCore1 的shell,让我们检查一下刚才建立的数据表是否正常。

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611055657828%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

从上图可以看到,想要建立的数据库都建立好了。现在,往available_acc数据表里插入100条示例账号:

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611055958359%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

提示信息说明100条数据插入成功。100012-100100的数据太长,截图太小无法完全显示出来。

我们测试一下,随意从刚刚插入的数据表里读取一条记录:

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611060234703%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

成功了!

现在,用相同的方法打开ChatServerExt模块的shell,不要建立该模块的数据库模式,而是从已经建立数据库模式的节点NodeChatCore1@localhost处拷贝数据库模式,我们看到,现在2个节点已经形成了一个集群。具体过程如下:

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611062855796%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

但除了schema,其他数据库都是运行在remote上的,也即远端的其他节点。而且,即使schema也只是运行在ram里的,无法持久化存储。现在,我们从现有节点处拷贝各数据库的配置文件:

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611064044218%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

再次查看,我们发现,我们需要的数据表已经运行在当前节点了,2个节点的数据库将保持同步和一致。

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611064249109%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

我们选择做个测试,在2个节点里执行相同的命令,可以看到,2个节点都能获得相同的数据了。

test.jsp?url=http%3A%2F%2Fimg.blog.csdn.net%2F20140611064546578%3Fwatermark%2F2%2Ftext%2FaHR0cDovL2Jsb2cuY3Nkbi5uZXQvc3RyOTk5X2Nu%2Ffont%2F5a6L5L2T%2Ffontsize%2F400%2Ffill%2FI0JBQkFCMA%3D%3D%2Fdissolve%2F70%2Fgravity%2FSouthEast&refer=http%3A%2F%2Fblog.csdn.net%2Fstr999_cn%2Farticle%2Fdetails%2F29988113

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值