
请原谅我使用java代码的风格来表示很多的终端命令,编辑器自带的样式太少了⋯⋯
先是给mysql配置~
(文中"/Users/XXX"代表当前用户主目录,我是在自己主目录下建了一个 Dev 目录,各种开发工具都放在里面,下文中的路径请根据自己实际目录作调整)
1、这里使用官网的tar.gz包,然后解压到 /Users/XXX/Dev/mysql 目录下
2、在 /Users/XXX/Dev/mysql/data 下新建目录 data1 和 data2
3、初始化数据库,在 terminal 执行如下shell :
cd /Users/XXX/Dev/mysql
./script/mysql_install_db --datadir=./data/data1
./script/mysql_install_db --datadir=./data/data2
4、mac下mysql默认是不需要 my.cnf 的,所以需要在 /Users/XXX/Dev/mysql 下新建 my.cnf 内容如下:
[mysqld_multi]
mysqld = /Users/XXX/Dev/mysql/bin/mysqld_safe
mysqladmin = /Users/XXX/Dev/mysql/bin/mysqladmin
user = root
#password = root
[mysqld1]
port = 3307
socket = /tmp/mysql.sock1
pid-file=/Users/XXX/Dev/mysql/data/data1/db-app1.pid
log=/Users/XXX/Dev/mysql/data/data1/db-app.log
datadir = /Users/XXX/Dev/mysql/data/data1
basedir = /Users/XXX/Dev/mysql
user = root
[mysqld2]
port = 3308
socket = /tmp/mysql.sock2
pid-file = /Users/XXX/Dev/mysql/data/data2/db-app2.pid
log=/Users/XXX/Dev/mysql/data/data2/db-app.log
datadir = /Users/XXX/Dev/mysql/data/data2
basedir = /Users/XXX/Dev/mysql
user = root
[mysqldump]
quick
max_allowed_packet = 16M
[mysql]
no-auto-rehash
[isamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M
[myisamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout
5、手动启动/关闭实例的命令(这里做测试用,后期改为自动启动将命令改为脚本执行)
启动:
/Users/XXX/Dev/mysql/bin/mysqld_multi --defaults-file=/Users/XXX/Dev/mysql/my.cnf start 1-2
注意:有些文章讲的是 –config-file ,但在5.5的版本里,已经没有该选项了。
起动时,会报找不到my_print_defaults。需要在PATH中添加bin目录。
关闭:
/Users/XXX/Dev/mysql/bin/mysqld_multi --defaults-file=/Users/XXX/Dev/mysql/my.cnf stop 1-2
或者
/Users/XXX/Dev/mysql/bin/mysqladmin -uroot -h 127.0.0.1 -P 3306 shutdown
其实mysqld_multi就是通过mysqladmin来实现关闭实例的。
############## 环境变量设置方法1 #################
打开shell后, 默认在$HOME目录下
键入: vi .bash_profile 回车, 编辑.bash_profile文件
按i进入插入文字编辑模式
找到设定PATH环境变量的一行,将你要添加的完整路径(如:/Users/XXX/Dev/mysql/bin)加入其中。如果没有找到设定PATH变量的行, 你可以自己添加一行:
export PATH=${PATH}:/Users/XXX/Dev/mysql/bin
############ 环境变量设置方法2(推荐) ##############
在 /etc/paths.d 建立一个文件专门表示mysql的path
1)浏览到 /etc/paths.d :
cd /etc/paths.d
2)创建文件:
sudo vi mysql
3)编辑模式下输入:
/Users/XXX/Dev/mysql/bin
4)可以在terminal下输入以下命令验证是否生效:
echo $PATH
6、修改root密码
mysqladmin -u root -h 127.0.0.1 -P 3307 password [yourpassword]
mysqladmin -u root -h 127.0.0.1 -P 3308 password [yourpassword]
20120229 补充:
使用mysqldump时需指定sock,比如备份3308端口的数据库时,须添加“ -S /tmp/mysql.sock2”
=================
到这里mysql配置完毕,开始设置开机自动启动=====================
主要做法是将脚本加入到StartupItems
1.首先,要放到 /Library/StartupItems 下的自定义启动项必须是一个目录,然后再把脚本放到目录下,而且脚本与目录必须同名,以启动项命名为 MysqlMulti 为例
terminal下执行:
cd /Library/StartupItems
sudo mkdir MysqlMulti
2.创建启动脚本
创建脚本文件:
sudo vi /Library/StartupItems/MysqlMulti/MysqlMulti
编辑模式下输入以下内容:
#!/bin/sh
# Source common setup, including hostconfig.
#
. /etc/rc.common
StartService( )
{
ConsoleMessage "Starting MySQL"
/Users/XXX/Dev/mysql/bin/mysqld_multi --defaults-file=/Users/XXX/Dev/mysql/my.cnf start 1-2
}
StopService( )
{
ConsoleMessage "Stopping MySQL"
/Users/XXX/Dev/mysql/bin/mysqld_multi --defaults-file=/Users/XXX/Dev/mysql/my.cnf stop 1-2
}
RestartService( )
{
ConsoleMessage "Restarting MySQL"
StopService
StartService
}
RunService "$1"
3.启动脚本描述、参数
创建描述文件:
sudo vi /Library/StartupItems/MysqlMulti/StartupParameters.plist
编辑模式下输入:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist SYSTEM "file://localhost/System/Library/DTDs/PropertyList.dtd">
<plist version="0.9">
<dict>
<key>Description</key>
<string>MysqlMulti</string>
<key>OrderPreference</key>
<string>Late</string>
<key>Provides</key>
<array>
<string>Launch mysql at startup</string>
</array>
</dict>
</plist>
至此,使用ls命令你将看到:
$ls /Library/StartupItems/MysqlMulti/
MysqlMulti StartupParameters.plist
4.修改权限
sudo chown -R root:wheel /Library/StartupItems/MysqlMulti
sudo chmod -R 755 /Library/StartupItems/MysqlMulti
5.
当设置完成后,可以在终端上用SystemStarter 来调试配置的信息
命令为:SystemStarter -n -D
根据提示的信息可以查看配置的问题。
6.启动时可能提示:
WARNING: my_print_defaults command not found.
Please make sure you have this command available and
in your path. The command is available from the latest
MySQL distribution.
查看 /Users/XXX/Dev/mysql/support-files/mysql.server 发现以下注释:
# If you install MySQL on some other places than /usr/local/mysql, then you
# have to do one of the following things for this script to work:
#|
# - Run this script from within the MySQL installation directory
# - Create a /etc/my.cnf file with the following information:
# [mysqld]|
# basedir=<path-to-mysql-installation-directory>
# - Add the above to any other configuration file (for example ~/.my.ini)
# and copy my_print_defaults to /usr/bin
# - Add the path to the mysql-installation-directory to the basedir variable
# below.
#
# If you want to affect other MySQL variables, you should make your changes
# in the /etc/my.cnf, ~/.my.cnf or other MySQL configuration files.
原来 my_print_defaults 需要拷贝到 /usr/bin ,干脆使用更方便的软连接:
sudo ln -s ~/Dev/mysql/bin/my_print_defaults /usr/bin/my_print_defaults
问题解决
分享到:
相关推荐
- **设置自启动**:使用 `systemctl enable mysqld` 设置 MySQL 服务开机自启动。 - **配置root用户密码**:通过 `grep 'temporary password' /var/log/mysqld.log` 获取临时密码,并使用 `mysql -uroot -p` 登录...
以下是常见的C++笔试面试题及其核心知识点解析,帮助您系统复习
计算机短期培训教案.pdf
计算机二级Access笔试题库.pdf
下是一份关于C++毕业答辩的心得总结,内容涵盖技术准备、答辩技巧和注意事项,供参考
内容概要:本文档详细介绍了英特尔为苹果公司构建的基于智能处理单元(IPU)的Cassandra集群的技术验证(PoC)。主要内容涵盖IPU存储用例、已建存储PoC、MEV到MMG400的过渡、苹果构建IPU-Cassandra集群的动机以及PoC开发进展。文档还探讨了硬件配置、软件环境设置、性能调优措施及其成果,特别是针对延迟和吞吐量的优化。此外,文档展示了六节点Cassandra集群的具体架构和测试结果,强调了成本和复杂性的降低。 适合人群:对分布式数据库系统、NoSQL数据库、IPU技术感兴趣的IT专业人员和技术管理人员。 使用场景及目标:适用于希望了解如何利用IPU提升Cassandra集群性能的企业技术人员。主要目标是展示如何通过IPU减少服务器部署的成本和功耗,同时提高数据处理效率。 其他说明:文档中涉及的内容属于机密级别,仅供特定授权人员查阅。文中提到的技术细节和测试结果对于评估IPU在大规模数据中心的应用潜力至关重要。
计算机二级考试C语言题.pdf
计算机发展史.pdf
计算机仿真技术系统的分析方法.pdf
yolo编程相关资源,python编程与YOLO算法组成的坐姿检测系统,功能介绍: 一:实时检测学生错误坐姿人数 二:通过前端阿里云平台显示上传数据,实现数据可视化
办公室网安全监控uptime-kuma,docker镜像离线压缩包
计算机课程设计-网络编程项目源码.zip
将该dll包放入项目并引用,可以操作打印机
杰奇2.3内核淡绿唯美小说网站源码 PC+手机版 自动采集 全站伪静态,送10.1版本关关采集器
计算机辅助教学.pdf
内容概要:本文详细介绍了如何利用天文相机和其他相关硬件设备搭建一套高画质、高帧率的流星监控系统,以及针对红色精灵闪电这一特殊自然现象的捕捉方法。文中不仅涵盖了硬件的选择标准如CMOS靶面尺寸、量子效率等重要参数,还提供了基于Python和OpenCV实现的基本监控代码示例,包括亮度突变检测、运动检测算法等关键技术点。此外,对于安装位置的选择、供电方式、成本控制等方面也有具体的指导建议。 适用人群:对天文摄影感兴趣的爱好者,尤其是希望捕捉流星和红色精灵闪电等瞬时天文现象的专业人士或业余玩家。 使用场景及目标:适用于希望搭建个人天文观测站,用于科学研究或个人兴趣爱好的场景。目标是能够稳定可靠地捕捉到流星和红色精灵闪电等难以捉摸的天文现象,为研究提供高质量的数据资料。 其他说明:文中提到的一些技术和方法虽然较为复杂,但对于有一定编程基础和技术动手能力的人来说是非常实用的参考资料。同时,文中提供的省钱技巧也为预算有限的用户提供了一些有价值的建议。
时间序列分析-基于R(第2版)习题数据
内容概要:本文详细介绍了如何使用LabVIEW通过网口读取阿特拉斯PM4000控制器的扭矩值。主要内容涵盖开放式通讯协议的理解、阿特拉斯调试软件和测试软件的应用、LabVIEW程序的具体实现步骤,包括初始化网络连接、发送读取扭矩值命令、接收并解析扭矩值数据,以及关闭网络连接。文中还提供了多个调试技巧和注意事项,如硬件接线配置、数据解析方法、常见错误及其解决办法,以及性能优化建议。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些需要集成阿特拉斯设备并与之进行数据交互的专业人士。 使用场景及目标:适用于需要实时监控和采集阿特拉斯PM4000控制器扭矩值的工业应用场景,旨在提高数据采集效率和准确性,确保设备运行状态的良好监测。 其他说明:文中提供的代码片段和调试经验有助于快速定位和解决问题,提升开发效率。此外,还强调了数据解析过程中需要注意的细节,如字节序问题和超时设置等。
计算机二级VB重点知识点解析.pdf