我正在使用 Java 编写一个 red5 应用程序 我正在使用 c3p0 进行数据库交互。
似乎在我的 MySQL 服务器中连接超时后,我的应用程序停止工作并建议配置 autoreconnect=true。
我该怎么做?
这是我用来创建数据源的函数:
private ComboPooledDataSource _createDataSource() {
Properties props = new Properties();
// Looks for the file 'database.properties' in {TOMCAT_HOME}\webapps\{RED5_HOME}\WEB-INF\
try {
FileInputStream in = new FileInputStream(System.getProperty("red5.config_root") + "/database.properties");
props.load(in);
in.close();
} catch (IOException ex) {
log.error("message: {}", ex.getMessage());
log.error("stack trace: " + ExceptionUtils.getFullStackTrace(ex));
return null;
}
// It will load the driver String from properties
String drivers = props.getProperty("jdbc.drivers");
String url = props.getProperty("jdbc.url");
String username = props.getProperty("jdbc.username");
String password = props.getProperty("jdbc.password");
ComboPooledDataSource cpds = new ComboPooledDataSource();
try {
cpds.setDriverClass(drivers);
} catch (PropertyVetoException ex) {
log.error("message: {}", ex.getMessage());
log.error("stack trace: " + ExceptionUtils.getFullStackTrace(ex));
return null;
}
cpds.setJdbcUrl(url);
cpds.setUser(username);
cpds.setPassword(password);
cpds.setMaxStatements(180);
return cpds;
}
最佳答案
创建一个文件 c3p0.properties,它必须位于类路径的根目录中:
# c3p0.properties
c3p0.testConnectionOnCheckout=true
有关更多文档,请参阅 this .
This post也可能有帮助。
关于java c3p0 : how can i configure autoreconnect=true?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3511422/
给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in
我对Ruby语言还很陌生(到目前为止我是用Groovy+Grails开发的)但是因为我对它很好奇所以我想在Ruby1.9.2-p0上试用Sinatra。我有一个简单的网站,它包含在/mywebpage中并且有2个文件:#blog.rbget'/'do'HelloWorld!'endget'/impossible'dohaml:indexend和#config.rupath=File.expand_path"../",__FILE__$LOAD_PATH然后在同一个文件夹中,我有一个包含index.haml的/views/文件夹。我尝试使用rackup-p8080运行服务器,但是当我尝试
我需要遍历数组并将提供的block应用于每个元素,并返回block返回的第一个真值,这意味着我需要在获得真值后立即停止。下面是我的代码。我是ruby新手,我不确定这段代码是否是在重新发明轮子。也许已经有一个或多个库方法可以做到这一点?还是可以简化此代码?RS={:x=>%w(\d+a\d+bb\d+ccc\d+).map{|x|/^#{x}$/},:y=>%w(\w+1\w+22\w+333\w+).map{|x|/^#{x}$/}}.freezedeffinds,tr=RS[s]ifrr.eachdo|p|m=p.matchtreturnmifmendnilendendpfind:x
长话短说,我正在编写一个包含选项参数的方法,如果键的值:if评估为真,该方法将执行某些操作。当我使用新语法在IRB中尝试哈希时,我在IRB中遇到语法错误,提示保持打开状态:1.9.3p374:010>{if:true}1.9.3p374:011?>使用旧语法,效果很好:1.9.3p374:011>{:if=>true}=>{:if=>true}开始语句的所有关键字都表现出相同的行为。例如。def,do,module,case出现在中间和class中的其他保留字可以正常工作:else、end我的问题是:这是预期的行为、错误还是限制? 最佳答案
TrueClass、FalseClass和NilClass有两个实例,名称不同:一个小写,一个大写。一个实例似乎对另一个实例进行评估:true#=>trueTRUE#=>truetrue==TRUE#=>true这两个常量之间有区别吗?如果有,区别是什么?如果它们相同,我应该在我的代码中使用这些常量中的哪一个?我应该写some_value=true还是some_value=TRUE? 最佳答案 不同之处在于,true是Ruby中的关键字,而TRUE是常量:true=1#=>SyntaxError:Can'tassigntotrueT
所以我尝试通过rbenv在运行在VirtualBox上的新ubuntu12.04LTS上安装ruby。我从https://github.com/sstephenson/rbenv得到了rbenv和ruby-build来自https://github.com/sstephenson/ruby-build.然后我运行以下但构建失败:(rbenvinstall2.0.0-p0Downloadingruby-2.0.0-p0.tar.gz...->http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p0.tar.gzInstallingru
我想查找某个字段不正确的所有记录。用于此的有效AR语法是:Dog.where(:stray=>[false,nil])是否有更简洁的方式来查询“nottrue”?到处都必须迎合这种mysql的细微差别,这真的很糟糕。 最佳答案 命名作用域怎么样?scope:not_stray,where("strayISNULLORstray=false")然后使用:Dog.not_stray 关于ruby-on-rails-ActiveRecord查询:whereafieldisnottrue,我们在
我听说过很多关于Ruby,甚至可能是Javascript是“真正的”面向对象的语言,而不是C++和C#,后者是面向类(或基于模板)的语言。真正的OO是什么意思,它相对于类/模板方法有什么优势? 最佳答案 这是一个用于推广语言的主观术语。我曾经看到有人说,与C++相比,C#和Java是真正的面向对象语言,因为一切都必须在一个类中(没有全局函数或变量),并且所有对象都继承自一个Object类。对于Ruby,它可能指的是Ruby如何将一切都视为一个对象,因此您可以编写1.to_s,而不是像str(1)或String.valueOf(1)。
我正在使用Ruby的case语法来设置一些基于self.class的简单逻辑,如下所示:caseself.classwhenFirstClassdostuff....whenSecondClassdootherstuff...end我很快意识到这总是返回nil。经过仔细调查,我发现case使用===而不是==检查是否相等。在我的终端中运行self.class==FirstClass时,我按预期得到true,但是self.class===FirstClass返回假的。查看ruby文档,我找到了followingexplanation===:CaseEquality–ForclassO
我需要索引我根据“真”和“假”定义的散列colorHash=Hash.new{|hash,key|hash[key]={}}colorHash["answers"][true]="#00CC00"colorHash["answers"][false]="#FFFFFF"出于测试目的,我使用rand(2)建立索引但失败了。如果我使用true进行索引,它就会起作用。我在找类似的东西rand(2).logical却一无所获。 最佳答案 有一种简单(虽然不是很令人兴奋)的方法可以做到这一点:rand(2)==1