- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
由于某种原因,我现在决定将我的webapp连接方法从简单的托管连接更改为池化DataSource。除了mysqldump会在BufferedReader上的迭代过程中导致OutOfMemoryError之外,其他所有方法都工作正常。如您在此处粘贴的代码所看到的,我尝试通过运行外部进程进行转储...因此我不知道为什么会出现此异常。
谁能帮我?
/**
* esegue il comando mysqldump e inserisce il risultato in un array di byte che poi verrà restituito sotto forma di stringa
* @return
* @throws Exception
*/
private String getData() throws Exception {
Process run = null;
InputStream inErr = null;
BufferedReader brErr = null;
StringBuffer tempErr = null;
InputStream in = null;
BufferedReader br = null;
StringBuffer temp = null;
try {
int count;
char[] cbuf = new char[BUFFER];
// esegue il backup con mysqldump
run = Runtime.getRuntime().exec("mysqldump --host=" + host + " --port=" + port + " --user=" + user + " --password=" + password + " " + db);
// prima gestisce un eventuale errore
inErr = run.getErrorStream();
brErr = new BufferedReader(new InputStreamReader(inErr));
tempErr = new StringBuffer();
if (inErr.available() != 0) {
while ((count = brErr.read(cbuf, 0, BUFFER)) != -1)
tempErr.append(cbuf, 0, count);
}
brErr.close();
inErr.close();
// scrive il testo dell'errore in un file
if (tempErr.toString().length() != 0) {
// scrive l'errore nel file di log
scriviErrInLog(tempErr.toString());
throw new Exception("Errore nel backup del database");
}
// ora gestisce un
in = run.getInputStream();
br = new BufferedReader(new InputStreamReader(in));
temp = new StringBuffer();
//System.out.println("creato input stream --- in.available() = " + in.available());
if ((count = br.read(cbuf, 0, BUFFER)) != -1) {
//System.out.println("sto per scrivere nel file");
temp.append(cbuf, 0, count);
br.mark(BUFFER);
br.reset();
while ((count = br.read(cbuf, 0, BUFFER)) != -1) {
temp.append(cbuf, 0, count);
}
//System.out.println("scritto");
br.close();
in.close();
run.destroy();
} else
throw new BackupException("Errore nel backup del database: backup vuoto");
} catch (Exception e) {
br.close();
in.close();
brErr.close();
inErr.close();
run.destroy();
throw e;
}
return temp.toString();
}
ott 15, 2013 3:51:08 PM org.apache.tomcat.jdbc.pool.ConnectionPool abandon
最佳答案
问题是,您试图将整个mysql转储保留在内存中,这必然会以这种错误结束。它与池化的DataSource没有任何关系。
从输入流中读取时,尝试逐行处理转储。
关于java - 如果tomcat使用数据源,由tomcat启动的mysqldump导致OutOfMemoryError,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19382460/
我定期针对 Drupal 数据库运行 mysqldump,伙计,那些缓存表可能会变得很大。考虑到我在重新加载数据后做的第一件事就是清除缓存,如果我可以完全跳过转储所有这些行,我会很高兴。我不想跳过表创
我知道 exit code = 0 的意思是 No error。 我得到 退出代码 = 2。这是什么意思 ? 在哪里可以看到 mysqldump 退出代码的完整列表? 最佳答案 取自 MySQL 5.
我正在清理这个庞大而困惑的数据库。它包含 500 多个表,这是将 Magento Enterprise 与 Joomla 结合到一个数据库中的结果。 更糟糕的是,有一组 70 多个 Joomla 表根
我正在尝试将大型数据库中的一小部分记录加载到测试数据库中。 你如何告诉 mysqldump 只给你 800 万条记录中的 n 条记录? 谢谢 最佳答案 正如 skaffman 所说,使用 --wher
我的 mysqldump 有问题.. 我知道如何从我的电脑启动 mysqldump 命令到远程服务器并自动将 mysqldump 文件保存在我的电脑中...... mysqldump --user=
这是我的完整 bash 脚本: #!/bin/bash logs="$HOME/sitedb_backups/log" mysql_user="user" mysql_password="pass"
在这个问题上工作了一整天..当我请求该表时,它为我提供了整个数据库.. #!/bin/bash # mysqldump --user root --password=mypw sellnjho_rea
我想知道通过phpmyadmin导出大型数据库和通过mysqldump通过终端导出信息的方式是否有区别。 mysqldump 的运行时间更好? 我想知道优点和缺点。 谢谢。 最佳答案 如果你从 mys
我收到以下错误: mysqldump: [ERROR] unknown variable 'database=myDB1' 当我运行这个命令时: mysqldump -u root -p myDB
我最近将服务器升级到 Debian 9,并将 MySQL 升级到最新版本。我有一个简单的备份脚本,在生产站点上执行任何工作之前运行该脚本,但这一次,在运行脚本时,我遇到以下情况: mysqldump:
解决方法见底 我正在运行 mysqldump 作为通过 cron 作业调用的 php 脚本的一部分。 是否可以从 mysqldump 命令返回 stderr,或者将其分配给可以直接读取的变量?或者是否
尝试通过 MySQL Workbench 转储简单数据库,方法是单击...服务器>数据导出>mydb>开始导出 获取消息:mysqldump 版本不匹配...消息显示这些版本mysqldump.exe
我尝试了其他答案中提到的其他解决方案,例如权限、授予问题、端口号、密码/用户名等。这些都不是问题;它们可能是您的问题,因此需要检查。 配置:在 Win10 上运行 Wordpress,安装了 Mari
我必须从服务器转储数据库,将 .sql 传输到另一台服务器,然后运行以下脚本以使用此语法删除某些行: DELETE wp_posts FROM wp_posts INNER JOIN wp_postm
正在尝试从 MAMP 服务器导出数据库。我试过命令: # mysql_dump -u root -proot db_name > db_name.sql # Applications/MAMP/Lib
我只想转储最新的行。但是当我通过 --where 选项时,它不会转储行。但是当我使用相同的 where 子句执行选择查询时,它返回行。这是我的选择查询: SELECT * FROM abc.`xyz
我用它来将所有数据从 my_database 导出到分隔文本到一个文件夹中 mysqldump -u root -p -t -T /path/to/export my_database --field
我经常使用以下命令通过 ssh 在 AWS RDS 上导出 mySql 数据库: mysqldump -u myUserName -h myDBname.randomcharacters.us-reg
我需要包含数据的 mysqldump,但在数据库中还有几个带有 FEDERATED 引擎的表。 mysqldump 也包括 FEDERATED 表的 INSERT,这是导致“重复条目”错误的原因(因为
mysqldump 在生成转储文件时会转义哪些字符?不幸的是,我找不到任何相关文档,所以我尝试了一下,发现只有双引号、单引号和反斜杠 (',",\) 会被反斜杠转义。 但是还有更多吗,或者有任何可用的
我是一名优秀的程序员,十分优秀!