UTF.COM.CN

同一台机器上运行同时运行多个mysql

作者:佚名 | 来源:网络 | 添加时间:2007-11-15 10:55:19 | 人气:432

同一台机器上运行同时运行多个mysql

一直是在一台机器上运行一个MYSQL服务,这几天一个MYSQL连接的问题一直在困扰我。我突然想到一个机器上可以同时运行多个APACHE,为什么就不能运行多个MYSQL呢?于是我说做就做。那个一直在困扰我的MYSQL连接的问题也解决了。(是delphi7连接mysql的问题,现在使用API的方法连接了。)

下面我把一个机器同时运行MYSQL4.0.21和MYSQL5.0.21的方法与过程写下来。

我现在使用的系统是windows2003 Enterprise Edition.
先准备好MYSQL4.0.21和MYSQL5.0.21的安装文件。下载地址是www.mysql.com/downloads MYSQL的官方网站。我从使用MYSQL开始都是在这里DOWNLOAD。
下载好后 就安装。我下载的MYSQL4.0.21和MYSQL5.0.21是免安装的ZIP包。分别解压安装在F:\mysql4与F:\mysql5。

在Windows命令行CMD下分别开启MySQL服务:
代码如下:
C:\> F:\MySQL4\bin\mysqld --install MySQL4 --defaults-file=F:\MySQL4\my.ini
C:\> F:\MySQL5\bin\mysqld --install MySQL5 --defaults-file=F:\MySQL5\my.ini

上面的命令复杂了点,我说明下
一般在mysqld后面加上 --install 就可以了。
在后面加上MySQL4 就是给出服务名字
给出了--defaults-file选项,是告诉服务器只从指定的文件读取 。 
如果没有给出--defaults-file选项,那么服务 器从标准选项文件中读取。
mysql4.0.21的配置文件my.ini在"c:\windows"下, mysql5.0.21的配置文件my.ini在自身安装下

下面修改下my.ini文件。
##### mysql4--my.ini #####
[mysqld]
basedir=F:/mysql4  #安装目录
datadir=F:/mysql4/data #数据库目录
port=3307 #服务器运行端口

下面的的5的是我上一个安装后保留下来
### mysql5--my.ini ###
#客户端设置
[client]
port=3306
#服务端设置
[mysql]
default-character-set=latin1 #默认语言
#客户端设置
[mysqld]
port=3306
basedir="D:/httpd/mysql5/"
datadir="D:/httpd/mysql5/Data/"
default-character-set=latin1
default-storage-engine=INNODB

#设置 模式
mode="STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,
NO_ENGINE_SUBSTITUTION"
max_connections=1023 #最大连接数
query_cache_size=25M #查询缓存
tmp_table_size=12M #临时表
thread_cache_size=30 #线程缓存

#*** MyISAM 设置 ***
myisam_max_sort_file_size=100G
myisam_max_extra_sort_file_size=100G
myisam_sort_buffer_size=8M
key_buffer_size=37M
read_buffer_size=64K
read_rnd_buffer_size=256K
sort_buffer_size=208K


#*** INNODB 设置 ***
innodb_additional_mem_pool_size=2M
innodb_flush_log_at_trx_commit=1
innodb_log_buffer_size=1M
innodb_buffer_pool_size=70M
innodb_log_file_size=14M
innodb_thread_concurrency=8

上面都配置好了就可以启动MYSQL4与mysql5了。
MYSQL5是默认端口3306 mysql4的端口是3307
连接mysql4的时候 要写出port=3307
$link mysql_connect("localhost:3307""mysql_user""mysql_password")
         or die(
"Could not connect: " mysql_error());


MySQL5.0.1开始就有了 可以在服务名字下设置一个 --local-service(本地服务)选项。这会使服务 器用LocalService Windows帐户运行。这种帐户只在Windows XP或更新的系统上才有。

实际上说白了就是在不通的端口下运行。

责任编辑:冬天来了
【字号: 】【去论坛讨论】【发表评论】【打印本文】【告诉好友】【关闭窗口
网友评论(评论内容只代表网友观点,与本站立场无关!)
  • yy 发表于:2008-04-19 16:08:29
    /*#include<stdio.h>
    #include<string.h>

    void Daoxu(char num[], int N)
    {
        char temp;
        char *i, *j;

        for(i = num, j = num  N - 1; j > i; j--, i )
        {
            temp = *i;
            *i = *j;
            *j = temp;
        }
        //printf("%s\n", num);
    }

    void Kobe(char num[], int N)
    {
        int i;
        
        for(i = 0; i < ((int)strlen(num)); i )
        {
            *(num  i) = (*(num  i)  5 - 48) % 10 48;
        }
        //printf("%s\n", num);
    }

    void Th(char num[], int N)
    {
        char *i, *j, temp;
        i = num;
        j = num  N - 1;

        temp = *i;
        *i = *j;
        *j = temp;
         printf("%s\n", num);
        
    }

    void main()
    {
        int N, flag, i = 0;
        char num[100];

        printf("请输入密码:");        
        do
        {

            flag = 1;
            gets(num);
            if(num[i] < '0' || num[i] > '9')
            {
                printf("输入有误,请重新输入");
                flag = 0;
            }
            
            i ;
            
        }while(flag == 0);
        N = strlen(num);

        
        printf("加迷后的密码为");
        Daoxu(num, N );
        Kobe(num, N);
        Th(num, N);
        
    }*/
    //-------------------------------------------------------------------------------------------------------------------------------
    #include<stdio.h>

    struct student
    {
        int num;
        char name[30];
        float score1;
        float score2;
        float score3;
        float scorepj;
    }stus[50];

    void Shuchu(struct student stus[], int i);
    void Paixu(struct student stus[], int i);
    void Charu(struct student stus[], int i);
    void Shanchu(struct student stus[], int i);
    void Display(struct student stus[], int i);

    void main()
    {
        int i = 0;

        printf("请输入学员的详细信息\n");
    /*    for(i = 0; ; i )
        {
        scanf("%d",

姓名:

验证码: 点击刷新