- 解决opensips启动时出现PID file /var/run/opensips.pid does not exist 的错误
Mindfulness code
视频云opensips
启动opensips时报下列错误[root@OpenSIPSopensips]#opensipsctlstartINFO:StartingOpenSIPS:ERROR:PIDfile/var/run/opensips.piddoesnotexist--OpenSIPSstartfailed查看日志文件[root@OpenSIPSopensips]#tail-f/var/log/messagesMa
- 关于OpenSIPS3.4的tls_mgm配置
无名387
OpenSIPSOpenSIPStls
建议配置好tabletls_mgm,而不是把证书写到模块参数里面,好处是证书更新之后运行mitls_reload即可下面是一个插表的例子:INSERTINTOtls_mgm(id,DOMAIN,match_ip_address,match_sip_domain,TYPE,METHOD,verify_cert,require_cert,certificate,private_key,crl_chec
- 比较Kamailio和OpenSIPS的重写contact函数
无名387
OpenSIPSKamailioNAT
Kamailio:调用set_contact_alias()之后,在原有的contact的后面增加参数,具体地说,就是网络地址,网络端口和transport,好处是收到后续请求之时可以恢复原有contact的内容(当然也有坏处,就是增加参数之后导致包大,可能超过MTU)OpenSIPS:调用fix_nated_contact()之后,用网络地址和网络端口直接覆盖了在原有的contact,那么当收到
- 测试OpenSIPS3.4.3的lua模块
无名387
OpenSIPSOpenSIPSlua
这几天测试OpenSIPS3.4.3的lua模块,记录如下:有bug,但能用但现实世界就是这样,总是不完美的,发现之后马上提了issue下面这段代码运行报错:functionfunc1(msg)xlog("ERR","Hello,OpenSIPS\n")--把ERR改成EEE就没问题endsipstate.c的127行明显有问题(读者自己去查阅源码,这里不贴了)功能比Kamailio的KEMI少,
- opensips federation-cachedb-cluster(联合位置集群数据)
Kamilio_OPS
mongodb数据库nosql
opensipsFederatedUserLocationCluster(联合位置集群)实现目标:用户随机注册到不同opensips实例上,并且usrloc数据是共享的,lookup("location","g")可被全局查询到,lookup("location")可查询到本地opensips实例的注册数据环境:两个opensips实例(版本:3.2.3)一个MySQL实例一个mongodb实例(
- OpenSIPS3.4组合topology_hiding模块和mid_registrar模块的路由脚本
无名387
OpenSIPSOpenSIPS拓扑隐藏
OpenSIPS3.4.3启用topology_hiding模块的主要考虑是,某些sip协议栈对record-route支持的不好启用mid_registrar模块,向FreeSWITCH注册,修改contact为OpenSIPS的地址,但不修改过期时间。不用path模块的主要考虑是,某些sipserver对path支持的不好测试环境:OpenSIPSip地址:172.20.10.6FreeSWI
- OpenSIPS的db_cachedb模块
无名387
OpenSIPSOpenSIPS
查了下模块资料,要先安装mongodb,但本人不熟悉mongodb,于是暂时不测试db_cachedb模块google查了下,找到了2个链接:https://users.opensips.narkive.com/UQYIQ8Zq/opensips-connecting-to-mongodb-replica-set-from-opensipshttps://github.com/OpenSIPS/o
- OpenSIPS3.2保存和恢复sdp
无名387
OpenSIPSOpenSIPS修复sdp
UACOpenSIPSUAS--->invitewithsdp-->--->invitewithsdp<---183withsdp<---183withsdp<---200withoutsdp<---200withoutsdp这是最近碰到的一个case,需要在路由里面做如下处理:收到183reply的时候保存sdp收到200reply的时候恢复sdp主要的路由代码如下:loadmodule"sip
- OpenSIPS3.4 cachedb_sql模块测试
无名387
OpenSIPSOpenSIPScache
先上路由脚本:#debug_mode=yeslog_level=3xlog_level=3stderror_enabled=nosyslog_enabled=yessyslog_facility=LOG_LOCAL0udp_workers=4socket=udp:127.0.0.1:5060#CUSTOMIZEMEsocket=tcp:127.0.0.1:5060#CUSTOMIZEME#setm
- opensip常用命令备忘
Westring
查看用户信息可以在mysql中,opensipdatabase的subscriber表。opensip配置文件所在目录:/usr/local/etc/opensips/opensips.cfg(注意必须用管理员权限查看)opensip的ip端口设置,对于外网租用的服务器注意要填写示例列表中的内网ip,5060。另外要在出入规则中把udp和5060端口设置好。opensip添加删除账户:opensi
- 比较Kamailio和OpenSIPS的dispatcher模块
无名387
KamailioOpenSIPSdispatcher
Kamailio的dispatcher模块我用的很多,很熟OpenSIPS有同名模块二者基本功能相同但真使起来,差别还是挺大的#OpenSIPSevent_route[E_DISPATCHER_STATUS]{#logeachtimeadispatcherdestination#changesitsstatusxlog("Dispatcherdestinationhasnewstatus");}O
- centos或ubuntu部署OpenSips
Blueeyedboy521
音视频C组件库centosubuntulinux
目录参考关于via和Record-Route的理论关于rport机制概述安装依赖centosubuntu下载选择安装模块(db_mysql)数据库版本5.7配置安装目录保存配置项安装配置日志配置数据库配置文件opensips.cfg生成特定配置文件备份旧文件,修改新文件修改数据库配置创建用户启动查询在线用户负载均衡常见错误ERROR:databaseenginenotspecified,pleas
- 快速安装方式安装开源OpenSIPS和CP控制界面
lonnng2004
opensipsmysqlopensipsCP
OpenSIPS是目前世界上主流的两个SIP软交换引擎(其中另外一个是kamailio)或者SIP信令服务器(个人认为是比较正确的称谓)。关于Opensips的基础和一些参数配置和安装方式笔者在很久以前的历史文档中有非常多的介绍。最近,很多用户使用OpenSIPS软交换平台做freeSBC或者其他的功能业务的实现,这些客户遇到很多的疑问和安装中也遇到很多问题,所以,为了让客户能够快速安装opens
- OpenSIPS3.2.15 userblacklist模块测试
无名387
OpenSIPS模块测试
loadmodule"userblacklist.so"modparam("userblacklist","use_domain",0)#不比较域名modparam("userblacklist","db_url","mysql://opensips:opensipsrw@localhost/opensips")route[check_user_black]{if(is_method("INVIT
- OpenSIPS自定义统计项目
无名387
OpenSIPSOPS自定义统计项目
有朋友问,怎么统计ops每日的呼叫量这就是需要自定义统计项目我第一感觉是dialog模块后来又查了下资料,statistics模块更合适,Kamailio也有同名模块
- 测试OpenSIPS3.2的uac_registrant模块
无名387
OpenSIPSOpenSIPSuac_registrant
试了试OpenSIPS3.2的uac_registrant模块,目标就是opensips向Kamailio注册,记录如下:kamailioip:192.168.31.63opensipsip:192.168.31.171向kamailiosubscriber表插入数据,username='1001',password='1234',启动kamailio向opensipsregistrant表插入数
- Kamailio uac_replace和uac_restore
无名387
Kamailiouac_replaceuac_restore
uac模块包含的内容很多,本文仅讨论uac_replace和uac_restore先比较二段路由代码:#路由1$fU="alice";$tU="bob";$du=...;t_relay();exit;#OpenSIPS3.2似乎不允许这样修改主被叫,不清楚是出于什么样的考虑#路由2uac_replace_from('"alice"',"sip:"+"alice"+"@"+$fd);uac_repl
- Freeswitch 高级主题之用kamailio负载均衡
voipmaker
KamailioFreeSwitch
kamailio的前身叫openser,和opensips是兄弟,作为出色的sipproxy,在大并发量使用时经常用于负载均衡媒体服务器Asterisk、Freeswitch等实现集群。1.安装kamailio参考上一篇文章安装:Centos6.4上源码安装kamailio4.12.配置kamailio下面为配置好的主配置文件,dispacher模块有一些参数需要注意,默认下一跳地址的配置支持数据
- kamailio dispatch负载均衡
flora_yao_bj
sipsip
kamailio的前身叫openser,和opensips是兄弟,作为出色的sipproxy,在大并发量使用时经常用于负载均衡媒体服务器Asterisk、Freeswitch等实现集群。1.安装kamailio参考上一篇文章安装:http://www.aiuxian.com/article/p-1454911.html2.配置kamailio下面为配置好的主配置文件,dispacher模块有一些参
- Opensips安装配置(以下操作均已centOS 6.3系统为准)
holybomb
centoslinux运维
1.安装依赖软件:a)Yumupdate//更新系统到最新b)安装以下所需依赖软件gccbisonflexmakeopenssllibmysqlclient-devmysql-serverc)安装radiusclient:1.wgethttp://pkgs.repoforge.org/radiusclient-ng/radiusclient-ng-0.5.6-5.el6.rf.x86_64.rpm
- opensips 安装 参考视频步骤如下
王高强_强哥
1、apt-getupdateapt-getinstallgitapt-getinstallvimapt-getinstallflexbisonlibncurses5-devapt-getinstalllibncurses-devapt-getinstalllibncurses5-devapt-getinstallbisonapt-getinstallyaccapt-getinstallm42、c
- 【opensips】ERROR:core:fm_malloc: not enough free shm memory
安安爸Chris
问题现象opensips出现启动异常:启动异常截图ERROR:core:fm_malloc:notenoughfreeshmmemory(560bytesleft,need720),pleaseincreasethe"-m"commandlineparameter!opensips的内存还有8G,为什么会报这种异常呢?原因分析opensips是一个多进程应用,它自身fork了很多进程出来。所以在内
- opensips-cli安装
sip代理
背景opensips版本在3.x的文章一方面比较少,另一方面相关的介绍部分过时。最近在研究opensips,所以一并把相关的文章详细列出来,敬请期待,linux版本是centos7.91.opensips-cli安装准备1.1python3.9.18安装opensips-cli源码安装地址:https://github.com/OpenSIPS/opensips-cli/blob/master/d
- kamailio 做sip代理服务应用
sip代理
背景最近在研究sip代理服务,国内大部分推荐使用opensips,第一时间安装opensips来学习,实际在使用中发现opensips3.x的坑很多,很多功能在2.x版本上有,但是在3.x上还未实现。光是sip做代理服务转发请求到freeswitch上,3.x版本配置上就没有一个能成功使用的示例,配置都是2.x的,很多参数还不适配。整了2天都没搞明白,果断弃坑,选用kamailio,此时才发现ka
- opensips-cli安装
sip代理
背景opensips版本在3.x的文章一方面比较少,另一方面相关的介绍部分过时。最近在研究opensips,所以一并把相关的文章详细列出来,敬请期待,linux版本是centos7.91.opensips-cli安装准备1.1python3.9.18安装opensips-cli源码安装地址:https://github.com/OpenSIPS/opensips-cli/blob/master/d
- OpenSIPS配置脚本结构-》opensips.cfg
举世无双勇
opensips
OpenSIPs的配置文件一般命名为opensips.cfg,它是一个自定义的类C风格的脚本。逻辑上,一般把脚本划分为三个部分:全局变量模块描述路由逻辑下面是一个简单的实例:#######GlobalParameters#########debug=3log_stderror=nofork=yeschildren=4listen=udp:127.0.0.1:5060#######ModulesSe
- 【opensips】使用tls加密后的sip流如何通过wireshark查看?
安安爸Chris
使用tls加密sip后,所有的sip都是密文,所以即使抓包,也无法查看到sip信令流。实际上如果有tls服务器端certificate的privatekey的话,是可以把tls的sip流解密的。前提条件在opensips上针对tls端口抓的pcap包这个包必须包含tls握手的全过程,从ClientHello/ServerHello开始获取到certificate的privatekey文件加密的tl
- OpenSIPS 通话中 UPDATE 请求导致没有声音问题
谈谈1974
随笔工具配置OpenSIPS服务器SIP
文章目录1.问题现象2.抓包排查3.问题分析及解决方案1.问题现象在SIP应用的开发中,通话一端听不到声音是比较常见的问题。一般来说,没有声音意味着RTP传输存在障碍,追根究底就是网络不通或者端口未开放等原因。但在实践中,真正造成RTP传输故障的原因各式各样,以下是笔者遇到的一个案例:坐席使用软电话注册到OpenSIPS,常驻拉起后拨打外部用户,媒体流传输正常坐席使用硬话机注册到OpenSIPS,
- ubuntu 安装opensips osip exosip
somgl
其他siposipexosip
1、安装包准备osip:http://ftp.gnu.org/gnu/osip/exosip:http://download.savannah.nongnu.org/releases/exosip/需要的软件apt-getinstallmakegccg++2、下载安装包wgethttp://ftp.gnu.org/gnu/osip/libosip2-3.6.0.tar.gzwgethttp://d
- opensips 环境搭建及验证功能
济夏
环境说明1.系统为centos2.安装的opensips版本为opensips-2.2.2安装mysqlwgethttp://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpmrpm-ivhmysql-community-release-el7-5.noarch.rpmyuminstallmysql-community-server
- 关于旗正规则引擎中的MD5加密问题
何必如此
jspMD5规则加密
一般情况下,为了防止个人隐私的泄露,我们都会对用户登录密码进行加密,使数据库相应字段保存的是加密后的字符串,而非原始密码。
在旗正规则引擎中,通过外部调用,可以实现MD5的加密,具体步骤如下:
1.在对象库中选择外部调用,选择“com.flagleader.util.MD5”,在子选项中选择“com.flagleader.util.MD5.getMD5ofStr({arg1})”;
2.在规
- 【Spark101】Scala Promise/Future在Spark中的应用
bit1129
Promise
Promise和Future是Scala用于异步调用并实现结果汇集的并发原语,Scala的Future同JUC里面的Future接口含义相同,Promise理解起来就有些绕。等有时间了再仔细的研究下Promise和Future的语义以及应用场景,具体参见Scala在线文档:http://docs.scala-lang.org/sips/completed/futures-promises.html
- spark sql 访问hive数据的配置详解
daizj
spark sqlhivethriftserver
spark sql 能够通过thriftserver 访问hive数据,默认spark编译的版本是不支持访问hive,因为hive依赖比较多,因此打的包中不包含hive和thriftserver,因此需要自己下载源码进行编译,将hive,thriftserver打包进去才能够访问,详细配置步骤如下:
1、下载源码
2、下载Maven,并配置
此配置简单,就略过
- HTTP 协议通信
周凡杨
javahttpclienthttp通信
一:简介
HTTPCLIENT,通过JAVA基于HTTP协议进行点与点间的通信!
二: 代码举例
测试类:
import java
- java unix时间戳转换
g21121
java
把java时间戳转换成unix时间戳:
Timestamp appointTime=Timestamp.valueOf(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date()))
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:m
- web报表工具FineReport常用函数的用法总结(报表函数)
老A不折腾
web报表finereport总结
说明:本次总结中,凡是以tableName或viewName作为参数因子的。函数在调用的时候均按照先从私有数据源中查找,然后再从公有数据源中查找的顺序。
CLASS
CLASS(object):返回object对象的所属的类。
CNMONEY
CNMONEY(number,unit)返回人民币大写。
number:需要转换的数值型的数。
unit:单位,
- java jni调用c++ 代码 报错
墙头上一根草
javaC++jni
#
# A fatal error has been detected by the Java Runtime Environment:
#
# EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00000000777c3290, pid=5632, tid=6656
#
# JRE version: Java(TM) SE Ru
- Spring中事件处理de小技巧
aijuans
springSpring 教程Spring 实例Spring 入门Spring3
Spring 中提供一些Aware相关de接口,BeanFactoryAware、 ApplicationContextAware、ResourceLoaderAware、ServletContextAware等等,其中最常用到de匙ApplicationContextAware.实现ApplicationContextAwaredeBean,在Bean被初始后,将会被注入 Applicati
- linux shell ls脚本样例
annan211
linuxlinux ls源码linux 源码
#! /bin/sh -
#查找输入文件的路径
#在查找路径下寻找一个或多个原始文件或文件模式
# 查找路径由特定的环境变量所定义
#标准输出所产生的结果 通常是查找路径下找到的每个文件的第一个实体的完整路径
# 或是filename :not found 的标准错误输出。
#如果文件没有找到 则退出码为0
#否则 即为找不到的文件个数
#语法 pathfind [--
- List,Set,Map遍历方式 (收集的资源,值得看一下)
百合不是茶
listsetMap遍历方式
List特点:元素有放入顺序,元素可重复
Map特点:元素按键值对存储,无放入顺序
Set特点:元素无放入顺序,元素不可重复(注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的)
List接口有三个实现类:LinkedList,ArrayList,Vector
LinkedList:底层基于链表实现,链表内存是散乱的,每一个元素存储本身
- 解决SimpleDateFormat的线程不安全问题的方法
bijian1013
javathread线程安全
在Java项目中,我们通常会自己写一个DateUtil类,处理日期和字符串的转换,如下所示:
public class DateUtil01 {
private SimpleDateFormat dateformat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
public void format(Date d
- http请求测试实例(采用fastjson解析)
bijian1013
http测试
在实际开发中,我们经常会去做http请求的开发,下面则是如何请求的单元测试小实例,仅供参考。
import java.util.HashMap;
import java.util.Map;
import org.apache.commons.httpclient.HttpClient;
import
- 【RPC框架Hessian三】Hessian 异常处理
bit1129
hessian
RPC异常处理概述
RPC异常处理指是,当客户端调用远端的服务,如果服务执行过程中发生异常,这个异常能否序列到客户端?
如果服务在执行过程中可能发生异常,那么在服务接口的声明中,就该声明该接口可能抛出的异常。
在Hessian中,服务器端发生异常,可以将异常信息从服务器端序列化到客户端,因为Exception本身是实现了Serializable的
- 【日志分析】日志分析工具
bit1129
日志分析
1. 网站日志实时分析工具 GoAccess
http://www.vpsee.com/2014/02/a-real-time-web-log-analyzer-goaccess/
2. 通过日志监控并收集 Java 应用程序性能数据(Perf4J)
http://www.ibm.com/developerworks/cn/java/j-lo-logforperf/
3.log.io
和
- nginx优化加强战斗力及遇到的坑解决
ronin47
nginx 优化
先说遇到个坑,第一个是负载问题,这个问题与架构有关,由于我设计架构多了两层,结果导致会话负载只转向一个。解决这样的问题思路有两个:一是改变负载策略,二是更改架构设计。
由于采用动静分离部署,而nginx又设计了静态,结果客户端去读nginx静态,访问量上来,页面加载很慢。解决:二者留其一。最好是保留apache服务器。
来以下优化:
- java-50-输入两棵二叉树A和B,判断树B是不是A的子结构
bylijinnan
java
思路来自:
http://zhedahht.blog.163.com/blog/static/25411174201011445550396/
import ljn.help.*;
public class HasSubtree {
/**Q50.
* 输入两棵二叉树A和B,判断树B是不是A的子结构。
例如,下图中的两棵树A和B,由于A中有一部分子树的结构和B是一
- mongoDB 备份与恢复
开窍的石头
mongDB备份与恢复
Mongodb导出与导入
1: 导入/导出可以操作的是本地的mongodb服务器,也可以是远程的.
所以,都有如下通用选项:
-h host 主机
--port port 端口
-u username 用户名
-p passwd 密码
2: mongoexport 导出json格式的文件
- [网络与通讯]椭圆轨道计算的一些问题
comsci
网络
如果按照中国古代农历的历法,现在应该是某个季节的开始,但是由于农历历法是3000年前的天文观测数据,如果按照现在的天文学记录来进行修正的话,这个季节已经过去一段时间了。。。。。
也就是说,还要再等3000年。才有机会了,太阳系的行星的椭圆轨道受到外来天体的干扰,轨道次序发生了变
- 软件专利如何申请
cuiyadll
软件专利申请
软件技术可以申请软件著作权以保护软件源代码,也可以申请发明专利以保护软件流程中的步骤执行方式。专利保护的是软件解决问题的思想,而软件著作权保护的是软件代码(即软件思想的表达形式)。例如,离线传送文件,那发明专利保护是如何实现离线传送文件。基于相同的软件思想,但实现离线传送的程序代码有千千万万种,每种代码都可以享有各自的软件著作权。申请一个软件发明专利的代理费大概需要5000-8000申请发明专利可
- Android学习笔记
darrenzhu
android
1.启动一个AVD
2.命令行运行adb shell可连接到AVD,这也就是命令行客户端
3.如何启动一个程序
am start -n package name/.activityName
am start -n com.example.helloworld/.MainActivity
启动Android设置工具的命令如下所示:
# am start -
- apache虚拟机配置,本地多域名访问本地网站
dcj3sjt126com
apache
现在假定你有两个目录,一个存在于 /htdocs/a,另一个存在于 /htdocs/b 。
现在你想要在本地测试的时候访问 www.freeman.com 对应的目录是 /xampp/htdocs/freeman ,访问 www.duchengjiu.com 对应的目录是 /htdocs/duchengjiu。
1、首先修改C盘WINDOWS\system32\drivers\etc目录下的
- yii2 restful web服务[速率限制]
dcj3sjt126com
PHPyii2
速率限制
为防止滥用,你应该考虑增加速率限制到您的API。 例如,您可以限制每个用户的API的使用是在10分钟内最多100次的API调用。 如果一个用户同一个时间段内太多的请求被接收, 将返回响应状态代码 429 (这意味着过多的请求)。
要启用速率限制, [[yii\web\User::identityClass|user identity class]] 应该实现 [[yii\filter
- Hadoop2.5.2安装——单机模式
eksliang
hadoophadoop单机部署
转载请出自出处:http://eksliang.iteye.com/blog/2185414 一、概述
Hadoop有三种模式 单机模式、伪分布模式和完全分布模式,这里先简单介绍单机模式 ,默认情况下,Hadoop被配置成一个非分布式模式,独立运行JAVA进程,适合开始做调试工作。
二、下载地址
Hadoop 网址http:
- LoadMoreListView+SwipeRefreshLayout(分页下拉)基本结构
gundumw100
android
一切为了快速迭代
import java.util.ArrayList;
import org.json.JSONObject;
import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.support.v4.widget.SwipeRefreshLayo
- 三道简单的前端HTML/CSS题目
ini
htmlWeb前端css题目
使用CSS为多个网页进行相同风格的布局和外观设置时,为了方便对这些网页进行修改,最好使用( )。http://hovertree.com/shortanswer/bjae/7bd72acca3206862.htm
在HTML中加入<table style=”color:red; font-size:10pt”>,此为( )。http://hovertree.com/s
- overrided方法编译错误
kane_xie
override
问题描述:
在实现类中的某一或某几个Override方法发生编译错误如下:
Name clash: The method put(String) of type XXXServiceImpl has the same erasure as put(String) of type XXXService but does not override it
当去掉@Over
- Java中使用代理IP获取网址内容(防IP被封,做数据爬虫)
mcj8089
免费代理IP代理IP数据爬虫JAVA设置代理IP爬虫封IP
推荐两个代理IP网站:
1. 全网代理IP:http://proxy.goubanjia.com/
2. 敲代码免费IP:http://ip.qiaodm.com/
Java语言有两种方式使用代理IP访问网址并获取内容,
方式一,设置System系统属性
// 设置代理IP
System.getProper
- Nodejs Express 报错之 listen EADDRINUSE
qiaolevip
每天进步一点点学习永无止境nodejs纵观千象
当你启动 nodejs服务报错:
>node app
Express server listening on port 80
events.js:85
throw er; // Unhandled 'error' event
^
Error: listen EADDRINUSE
at exports._errnoException (
- C++中三种new的用法
_荆棘鸟_
C++new
转载自:http://news.ccidnet.com/art/32855/20100713/2114025_1.html
作者: mt
其一是new operator,也叫new表达式;其二是operator new,也叫new操作符。这两个英文名称起的也太绝了,很容易搞混,那就记中文名称吧。new表达式比较常见,也最常用,例如:
string* ps = new string("
- Ruby深入研究笔记1
wudixiaotie
Ruby
module是可以定义private方法的
module MTest
def aaa
puts "aaa"
private_method
end
private
def private_method
puts "this is private_method"
end
end