编译OpenSIPS使用连接源码安装的MySQL

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

因项目的需求,低版本的MySQL在性能上不能满足我们的需求,现在需要更换为高版本的MySQL 5.5.44.新版本的MySQL 5.5.44在性能上,比起CentOS 5.11自带的低版本的MySQL 5.0.95,至少要高一倍以上。


MySQL 5.5.44的安装,我们这边就不采用源码安装而是直接使用编译好的版本。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
yum -y  install  gcc gcc-devel gcc-c++ gcc-c++-devel libaio-devel boost boost-devel autoconf* automake* zlib* libxml* ncurses-devel ncurses libgcrypt* libtool* cmake openssl openssl-devel bison bison-devel unzip
 
groupadd -g 10001 mysql 
useradd  -u 10001 -s  /sbin/nologin  -d  /dev/null  -g mysql mysql
 
mkdir  /data
 
wget http: //mirrors .sohu.com /mysql/MySQL-5 .5 /mysql-5 .5.44-linux2.6-x86_64. tar .gz
tar  zxf mysql-5.5.44-linux2.6-x86_64. tar .gz
 
mv  mysql-5.5.44-linux2.6-x86_64  /data/mysql5 .5.44
 
echo  "127.0.0.1 $HOSTNAME" >> /etc/hosts
 
chown  -R mysql.mysql  /data/mysql5 .5.44 /data
 
/data/mysql5 .5.44 /scripts/mysql_install_db  --user=mysql --group=mysql --basedir= /data/mysql5 .5.44  --datadir= /data/mysql5 .5.44 /data
cp  /data/mysql5 .5.44 /support-files/my-medium .cnf  /etc/my .cnf
cp  /data/mysql5 .5.44 /support-files/mysql .server  /etc/init .d /mysqld
 
sed  -i  's#^basedir=$#basedir=/data/mysql5.5.44#g'  /etc/init .d /mysqld
sed  -i  's#^datadir=$#datadir=/data/mysql5.5.44/data#g'  /etc/init .d /mysqld
 
chmod  750  /etc/init .d /mysqld
 
service mysqld start
 
ln  -s  /data/mysql5 .5.44 /bin/ /usr/bin/
 
mysqladmin -uroot password 123456
 
mysql -uroot -p123456 -e  'delete from mysql.user where password=""'
 
mysql -uroot -p123456 -e  'drop database test'

以上MySQL就已经正常安装及使用。


源码安装请参阅:http://fengwan.blog.51cto.com/508652/1363566


现在编译安装OpenSIPS,你会发现无法编译

这个时候是因为OpenSIPS找不到MySQL的库,如果yum安装的话至少要安装mysql及mysql-devel.

我们这里就不yum安装了,因为已经安装了mysql。

1
2
3
4
5
6
7
ln  -s  /data/mysql5 .5.44 /bin/ /usr/bin/
 
ln  -s  /data/mysql5 .5.44 /include/  /usr/include/mysql
 
ln  -s  /data/mysql5 .5.44 /lib/  /usr/lib64/mysql
 
ln  -s  /data/mysql5 .5.44 /lib/ /usr/lib64/

将以上库及包含文件软链接即可正常。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
yum -y  install  gcc  make  zlib-devel wget 
yum -y  install  flex bison ncurses-devel openssl-devel
yum -y  install  lynx svn libxslt
wget http: //opensips .org /pub/opensips/1 .11.5 /src/opensips-1 .11.5-latest_src. tar .gz
tar  zxf opensips-1.11.5-latest_src. tar .gz
cd  opensips-1.11.5-tls/
make  prefix= /data/opensips1 .11.5 all include_modules= "db_mysql" 
make  prefix= /data/opensips1 .11.5  install  include_modules= "db_mysql"
cd
 
sed  -i  's/\# DBENGINE=MYSQL/DBENGINE=MYSQL/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc 
sed  -i  's/\# DBHOST=localhost/DBHOST=localhost/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc
sed  -i  's/\# DBNAME=opensips/DBNAME=opensips/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc 
sed  -i  's/\# DBRWUSER=opensips/DBRWUSER=opensips/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc 
sed  -i  's/\# DBRWPW="opensipsrw"/DBRWPW="opensipsrw"/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc 
sed  -i  's/\# DBROOTUSER="root"/DBROOTUSER="root"/g'  /data/opensips1 .11.5 /etc/opensips/opensipsctlrc 
 
ln  -s  /data/opensips1 .11.5 /etc/opensips/  /etc/
echo  'export PATH=$PATH:/data/opensips1.11.5/sbin/'  >> /etc/profile
source  /etc/profile
 
/data/opensips1 .11.5 /sbin/opensipsdbctl  create
 
/data/opensips1 .11.5 /sbin/osipsconfig 
 
rm  -f  /data/opensips1 .11.5 /etc/opensips/opensips .cfg
mv  /data/opensips1 .11.5 /etc/opensips/opensips_residential_ *.cfg  /data/opensips1 .11.5 /etc/opensips/opensips .cfg
 
 
sed  -i  's/disable_tcp=no/disable_tcp=yes/g'  /data/opensips1 .11.5 /etc/opensips/opensips .cfg 
sed  -i  's/listen=udp:127.0.0.1:5060/listen=udp:eth0:5060/g'  /data/opensips1 .11.5 /etc/opensips/opensips .cfg 
sed  -i  's#mpath="/usr/local/lib/opensips/modules/"#mpath="/data/opensips1.11.5/lib64/opensips/modules/"#g' 
 
/data/opensips1 .11.5 /etc/opensips/opensips .cfg 
sed  -i -e  '/modparam("uri", "use_uri_table", 0)/a\modparam("uri", "db_url","mysql://opensips:opensipsrw@localhost/opensips")' 
 
/data/opensips1 .11.5 /etc/opensips/opensips .cfg 
 
echo  "local0.* /var/log/opensips.log"  >>  /etc/syslog .conf 
service syslog restart 
 
mysql -uroot -p123456 -e  "insert into opensips.domain(domain) values('192.168.1.245')" 
#192.168.1.245为你的sip域,可以为ip
 
cp  /root/opensips-1 .11.5-tls /packaging/fedora/opensips .init  /etc/init .d /opensips 
sed  -i  's#cfgdir="/etc/$prog"#cfgdir="/data/opensips1.11.5/etc/$prog"#g'  /etc/init .d /opensips
sed  -i  's#opensips=/usr/sbin/$prog#opensips=/data/opensips1.11.5/sbin/$prog#g'  /etc/init .d /opensips 
chmod  +x  /etc/init .d /opensips 
groupadd opensips 
useradd  -g opensips -s  /sbin/nologin  -d  /dev/null  opensips 
service opensips start

若有不懂的,参阅http://fengwan.blog.51cto.com/508652/1655265


若启动OpenSIPS的时候出现

1
ERROR:core:sr_load_module: could not  open  module < /data/opensips1 .11.5 /lib64/opensips/modules/db_mysql .so>: libmysqlclient.so.  18: cannot  open  shared object  file : No such  file  or directory

运行

1
ln  -s  /data/mysql5 .5.44 /lib/ /usr/lib64/

将库链接上即可


本文转自 rong341233 51CTO博客,原文链接:http://blog.51cto.com/fengwan/1669752


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
6天前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
41 1
|
8天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置服务等,并与使用 RPM 包安装进行了对比,帮助读者根据需求选择合适的方法。编译源码安装虽然复杂,但提供了更高的定制性和灵活性。
63 2
|
10天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
【10月更文挑战第7天】本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据自身需求选择合适的方法。
19 3
|
9天前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
14 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
8天前
|
SQL JavaScript 关系型数据库
Node.js 连接 MySQL
10月更文挑战第9天
13 0
|
11天前
|
关系型数据库 MySQL Linux
Navicat 连接 Windows、Linux系统下的MySQL 各种错误,修改密码。
使用Navicat连接Windows和Linux系统下的MySQL时可能遇到的四种错误及其解决方法,包括错误代码2003、1045和2013,以及如何修改MySQL密码。
96 0
|
1月前
|
SQL JavaScript 关系型数据库
Node服务连接Mysql数据库
本文介绍了如何在Node服务中连接MySQL数据库,并实现心跳包连接机制。
32 0
Node服务连接Mysql数据库
|
1月前
|
关系型数据库 MySQL 数据库
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
docker启动mysql多实例连接报错Can’t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock’
111 0
|
9天前
|
存储 SQL 关系型数据库
Mysql学习笔记(二):数据库命令行代码总结
这篇文章是关于MySQL数据库命令行操作的总结,包括登录、退出、查看时间与版本、数据库和数据表的基本操作(如创建、删除、查看)、数据的增删改查等。它还涉及了如何通过SQL语句进行条件查询、模糊查询、范围查询和限制查询,以及如何进行表结构的修改。这些内容对于初学者来说非常实用,是学习MySQL数据库管理的基础。
43 6
|
7天前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
38 3
Mysql(4)—数据库索引