使用FREDATED引擎实现跨实例访问

    跨数据库服务器,跨实例访问是比较常见的一种访问方式,在Oracle中可以通过DB LINK的方式来实现。对于MySQL而言,有一个FEDERATED存储引擎与之相对应。同样也是通过创建一个链接方式的形式来访问远程服务器上的数据。本文简要描述了FEDERATED存储引擎,以及演示了基于FEDERATED存储引擎跨实例访问的示例。

 

1、FEDERATED存储引擎的描述
  FEDERATED存储引擎允许在不使用复制或集群技术的情况下实现远程访问数据库
  创建基于FEDERATED存储引擎表的时候,服务器在数据库目录仅创建一个表定义文件,即以表名开头的.frm文件。
  FEDERATED存储引擎表无任何数据存储到本地,即没有.myd文件
  对于远程服务器上表的操作与本地表操作一样,仅仅是数据位于远程服务器
  基本流程如下:    

  

2、安装与启用FEDERATED存储引擎
  源码安装MySQL时使用DWITH_FEDERATED_STORAGE_ENGINE来配置
  rpm安装方式缺省情况下已安装,只需要启用该功能即可

 

3、准备远程服务器环境

-- 此演示中远程服务器与本地服务器为同一服务器上的多版本多实例
-- 假定远程服务为:5.6.12(实例3406)
-- 假定本地服务器:5.6.21(实例3306)
-- 基于实例3306创建FEDERATED存储引擎表test.federated_engine以到达访问实例3406数据库tempdb.tb_engine的目的

[root@rhel64a ~]# cat /etc/issue
Red Hat Enterprise Linux Server release 6.4 (Santiago) 

--启动3406的实例
[root@rhel64a ~]# /u01/app/mysql/bin/mysqld_multi start 3406
[root@rhel64a ~]# mysql -uroot -pxxx -P3406 --protocol=tcp

root@localhost[(none)]> show variables like 'server_id';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| server_id     | 3406  |
+---------------+-------+

--实例3406的版本号
root@localhost[tempdb]> show variables like 'version';
+---------------+------------+
| Variable_name | Value      |
+---------------+------------+
| version       | 5.6.12-log |
+---------------+------------+

--创建数据库
root@localhost[(none)]> create database tempdb;
Query OK, 1 row affected (0.00 sec)

-- Author : Leshami
-- Blog   :http://blog.csdn.net/leshami

root@localhost[(none)]> use tempdb
Database changed

--创建用于访问的表
root@localhost[tempdb]> create table tb_engine as
    -> select engine,support,comment from information_schema.engines;
Query OK, 9 rows affected (0.10 sec)
Records: 9  Duplicates: 0  Warnings: 0

--提取表的SQL语句用于创建为FEDERATED存储引擎表
root@localhost[tempdb]> show create table tb_engine \G
*************************** 1. row ***************************
       Table: tb_engine
Create Table: CREATE TABLE `tb_engine` (
  `engine` varchar(64) NOT NULL DEFAULT '',
  `support` varchar(8) NOT NULL DEFAULT '',
  `comment` varchar(80) NOT NULL DEFAULT ''
) ENGINE=InnoDB DEFAULT CHARSET=utf8

--创建用于远程访问的账户
root@localhost[tempdb]> grant all privileges on tempdb.* to 'remote_user'@'192.168.1.131' identified by 'xxx';
Query OK, 0 rows affected (0.00 sec)

root@localhost[tempdb]> flush privileges;
Query OK, 0 rows affected (0.00 sec)

4、演示FEDERATED存储引擎跨实例访问

[root@rhel64a ~]# mysql -uroot -pxxx

root@localhost[(none)]> show variables like 'version';
+---------------+--------+
| Variable_name | Value  |
+---------------+--------+
| version       | 5.6.21 |
+---------------+--------+

#查看是否支持FEDERATED引擎
root@localhost[(none)]> select * from information_schema.engines where engine='federated';
+-----------+---------+--------------------------------+--------------+------+------------+
| ENGINE    | SUPPORT | COMMENT                        | TRANSACTIONS | XA   | SAVEPOINTS |
+-----------+---------+--------------------------------+--------------+------+------------+
| FEDERATED | NO      | Federated MySQL storage engine | NULL         | NULL | NULL       |
+-----------+---------+--------------------------------+--------------+------+------------+

root@localhost[(none)]> exit
[root@rhel64a ~]# service mysql stop
Shutting down MySQL..[  OK  ]
#配置启用FEDERATED引擎
[root@rhel64a ~]# vi /etc/my.cnf
[root@rhel64a ~]# tail -7 /etc/my.cnf
[mysqld]
socket = /tmp/mysql3306.sock
port = 3306
pid-file = /var/lib/mysql/my3306.pid
user = mysql
server-id=3306/
federated         #添加该选项
[root@rhel64a ~]# service mysql start
Starting MySQL.[  OK  ]
[root@rhel64a ~]# mysql -uroot -pxxx
root@localhost[(none)]> select * from information_schema.engines where engine='federated';
+-----------+---------+--------------------------------+--------------+------+------------+
| ENGINE    | SUPPORT | COMMENT                        | TRANSACTIONS | XA   | SAVEPOINTS |
+-----------+---------+--------------------------------+--------------+------+------------+
| FEDERATED | YES     | Federated MySQL storage engine | NO           | NO   | NO         |
+-----------+---------+--------------------------------+--------------+------+------------+

root@localhost[(none)]> use test

-- 创建基于FEDERATED引擎的表federated_engine
root@localhost[test]> CREATE TABLE `federated_engine` (
    ->   `engine` varchar(64) NOT NULL DEFAULT '',
    ->   `support` varchar(8) NOT NULL DEFAULT '',
    ->   `comment` varchar(80) NOT NULL DEFAULT ''
    -> ) ENGINE=FEDERATED DEFAULT CHARSET=utf8
    -> CONNECTION='mysql://remote_user:xxx@192.168.1.131:3406/tempdb/tb_engine';
Query OK, 0 rows affected (0.00 sec)

-- 下面是创建后表格式文件
root@localhost[test]> system ls -hltr /var/lib/mysql/test
total 12K
-rw-rw---- 1 mysql mysql 8.5K Oct 24 08:22 federated_engine.frm

--查询表federated_engine
root@localhost[test]> select * from federated_engine limit 2;
+------------+---------+---------------------------------------+
| engine     | support | comment                               |
+------------+---------+---------------------------------------+
| MRG_MYISAM | YES     | Collection of identical MyISAM tables |
| CSV        | YES     | CSV storage engine                    |
+------------+---------+---------------------------------------+

--更新表federated_engine
root@localhost[test]> update federated_engine set support='NO' where engine='CSV';
Query OK, 1 row affected (0.03 sec)
Rows matched: 1  Changed: 1  Warnings: 0

--查看更新后的结果
root@localhost[test]> select * from federated_engine where engine='CSV';
+--------+---------+--------------------+
| engine | support | comment            |
+--------+---------+--------------------+
| CSV    | NO      | CSV storage engine |
+--------+---------+--------------------+

5、创建FEDERATED引擎表的链接方式
scheme://user_name[:password]@host_name[:port_num]/db_name/tbl_name

    scheme: A recognized connection protocol. Only mysql is supported as the scheme value at this point.
    user_name: The user name for the connection. This user must have been created on the remote server, and must have suitable privileges to perform the required actions (SELECT, INSERT,UPDATE, and so forth) on the remote table.
    password: (Optional) The corresponding password for user_name.
    host_name: The host name or IP address of the remote server.
    port_num: (Optional) The port number for the remote server. The default is 3306.
    db_name: The name of the database holding the remote table.
    tbl_name: The name of the remote table. The name of the local and the remote table do not have to match.

链接示例样本:
    CONNECTION='mysql://username:password@hostname:port/database/tablename'
    CONNECTION='mysql://username@hostname/database/tablename'
    CONNECTION='mysql://username:password@hostname/database/tablename'

 

6、涉及到的相关参考
    MySQL多实例配置(一)
    MySQL多实例配置(二)
    Linux 下MySQL源码安装完整版    MySQL 用户与权限管理

时间: 2024-09-17 04:51:23

使用FREDATED引擎实现跨实例访问的相关文章

MySQL中使用FREDATED引擎实现跨数据库服务器、跨实例访问_Mysql

跨数据库服务器,跨实例访问是比较常见的一种访问方式,在Oracle中可以通过DB LINK的方式来实现.对于MySQL而言,有一个FEDERATED存储引擎与之相对应.同样也是通过创建一个链接方式的形式来访问远程服务器上的数据.本文简要描述了FEDERATED存储引擎,以及演示了基于FEDERATED存储引擎跨实例访问的示例. 1.FEDERATED存储引擎的描述   FEDERATED存储引擎允许在不使用复制或集群技术的情况下实现远程访问数据库   创建基于FEDERATED存储引擎表的时候,

浅析用FREDATED引擎实现MySQL跨实例跨数据库服务器查询教程

1.FEDERATED存储引擎的描述 FEDERATED存储引擎允许在不使用复制或集群技术的情况下实现远程访问数据库 创建基于FEDERATED存储引擎表的时候,服务器在数据库目录仅创建一个表定义文件,即以表名开头的.frm文件. FEDERATED存储引擎表无任何数据存储到本地,即没有.myd文件 对于远程服务器上表的操作与本地表操作一样,仅仅是数据位于远程服务器 基本流程如下: 2.安装与启用FEDERATED存储引擎 源码安装MySQL时使用DWITH_FEDERATED_STORAGE_

asp.net中WebResponse 跨域访问实例代码

 一篇朋友很久前写的asp.net中WebResponse 跨域访问示例,下面我转过来与大家一起学习学习,希望文章对大家会有帮助 前两天,一个朋友让我帮他写这样一个程序:在asp.net里面访问asp的页面,把数据提交对方的数据库后,根据返回的值(返回值为:OK或ERROR),如果为OK再把填入本地数据库.当时,想当然,觉得很简单,用js的xmlhttp ,如果根据response 的值是"OK"就执行提交本地数据库.很快写完发过去,让朋友试试,一试发现不行,后来一问,原来是跨域访问,

如何解决Entity Framework查询匿名对象后的跨域访问

在Entity Framework中,可以使用lambda表达式进行对数据的查询,而且可以将查询结果直接映射为对象或者对象列表,这极大的提高的开发速度,并且使数据层的数据更加方便处理和传递.但是很多时候,我们不需要把整个表的字段都查出来,如果我们直接把整个数据实体查询出来,就极大的影响了性能,所以我们需要通过查询匿名对象或者已经定义的方式,对数据库进行查询: 1.实例使用的数据实体类: publicclass Category {publicint Id { get; set; }publics

Web安全技术之浏览器的跨域访问

 一.浏览器介绍 对于Web应用来说,浏览器是最重要的客户端. 目前浏览器五花八门多得不得了,除了Chrome.IE.Firefox.Safari.Opera这些国外的浏览器外,百度.腾讯.360.淘宝.搜狗.傲游之类的,反正能做的都做了. 浏览器虽然这么多,但浏览器内核主要就以下4种: Trident:IE使用的内核. Gecko:Firefox使用的内核. WebKit:Safair和Chrome使用的内核.WebKit由苹果发明,Chrome也用了,但是Google又开发了V8引擎替换掉了

php跨服务器访问方法小结

  本文实例总结了php跨服务器访问方法.分享给大家供大家参考.具体分析如下: 近来项目中遇到跨服务器访问的问题,研究了好些日子,总结如下: 1.用file_get_contents方法 ? 1 2 3 $host = 'url'; $randomNumber=file_get_contents($host); echo $$randomNumber; 2.用Curl ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 $host = 'url'; $ch = curl_ini

jquery异步跨域访问代码

下面是关于jquery异步跨域访问的简单实例,需要的朋友可以参考一下   复制代码 代码如下: /* $.ajax({ url : url, type : 'POST', data : { CorpID : CorpID, Pwd : Pwd, Mobile : Mobile, Content : Content, Cell : '', SendTime : '' }, async : true,//异步 dataType : 'text',//'text','jsonp' success :

连续2周多次Hang,只因应用大量跨节点访问RAC数据库!

 一.故障现象某客户核心系统数据库工作日生产时间发现会话积压,存在大量异常等待事件,部分节点所有联机日志组全部处于Active状态,无法完成数据库检查点,数据库实例处于Hang住的状态.   第二周几乎相同时间发生同样的问题,但由于第一次已经提出预案,所以问题影响得到控制,同时采集到更多分析信息,最终彻底解决了该问题.   环境介绍: IBM Power8 E880 AIX 7.1  Oracle  4-nodes RAC(11.2.0.3.15)    二.故障预案第一次故障发生后,提出以下预

php跨服务器访问方法小结_php技巧

本文实例总结了php跨服务器访问方法.分享给大家供大家参考.具体分析如下: 近来项目中遇到跨服务器访问的问题,研究了好些日子,总结如下: 1.用file_get_contents方法 $host = 'url'; $randomNumber=file_get_contents($host); echo $$randomNumber; 2.用Curl $host = 'url'; $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $host); //