自动备份MySQL数据库 [更新bug]
作者:V君 发布于:2015-6-23 22:32 Tuesday 分类:折腾手记
鉴于树莓派是用SD卡作为存储器, 然而SD卡是十分脆弱的,
稍有不慎就会文件系统损坏,因此完善的备份措施是必不可少.
于是开始咕狗整个数据库的备份方法,
嗯 mysqldump 这货只要指定数据库名称就能把整个数据库变成SQL输出来
接下来是遍历所有数据库, 还要排除不必要的系统数据库和架构数据库.
参考了咕狗来的一篇文章,按自己的需求改了下代码, 主要还是打日志 (=゚ω゚)=
依然是塞给crontab去执行
#!/bin/bash
# Add your backup dir location, password, mysql location and mysqldump location
DATE=$(date +%Y-%m-%d_%H-%M-%S)
BACKUP_DIR="/mnt/BackupStore/dbs"
MYSQL_HOST="192.168.***.***"
MYSQL_USER="root"
MYSQL_PASSWORD="********"
MYSQL=mysql
MYSQLDUMP=mysqldump
echo $DATE begin backup database
# To create a new directory into backup directory location
mkdir -p $BACKUP_DIR/$DATE
# get a list of databases
databases=`$MYSQL -h$MYSQL_HOST -u$MYSQL_USER -p$MYSQL_PASSWORD -e "SHOW DATABASES;"|grep -Ev "(information_schema|performance_schema|mysql)"|sed 1d`
# dump each database in separate name
for db in $databases; do
echo backing up $db
$MYSQLDUMP --force --opt --user=$MYSQL_USER -h$MYSQL_HOST -p$MYSQL_PASSWORD --databases $db | xz > "$BACKUP_DIR/$DATE/$db.sql.xz"
done
echo done.
update1:修正包含DataBase的数据库被排除
~
Entity Framework 就是个坑
作者:V君 发布于:2014-8-9 13:59 Saturday 分类:折腾手记
前些天整到个 sqlite-net , 支持Linq的轻量级sqlite组件. 起初用着还顺手的
用着用着就马丹了 -- 不支持连表查询/复杂投影, 我了个去!
还是回到DataContext吧... 要么DbLinq 要么实体框架,前者之前用过知道略buggy.
是时候该上手EF了.
>>> 上手吧 <<<
■去Sqlite官网下载组件安装包
由于现在只用到.net4的级别就下了对应安装包
装好(x86/x64)之后发现设计器并没有增加提供程序, 后来才发现 原来vs2013需要4.5.1的才行
果断下一个来装,总算是见到2013的集成选项了,安装过程依次出现数个命令行窗口
最后一个停在Install.exe上,等了几分钟,命令行窗口总算消失了, 安装向导完成!
乖乖的, 数据提供程序出来啦!
创建数据库连接时出现了莫名其妙的错误
整了半天 各种版本与提供程序不兼容.. 并且EF还依赖于设计器生成的xml嵌入资源 -- 这跟嗨布馁没差别啊魂淡.
放弃治疗, 要么不做复杂投影, 要么回到buggy的dbLinq..
(偷偷更新:后来还发现了linq2db这货支持复杂投影也能自动生成实体类(T4), 用着还可以)
让mono也能用DynamicExpression::ParseLambda
作者:V君 发布于:2014-7-22 13:29 Tuesday 分类:折腾手记
网上一直传的反射 System.Web.Extensions 的私有类
System.Web.Query.Dynamic.DynamicExpression
中的 ParseLambda 方法来实现动态lambda表达式
Assembly asm = typeof(UpdatePanel).Assembly;
Type dynamicExpressionType =
asm.GetType("System.Web.Query.Dynamic.DynamicExpression");
MethodInfo parseLambdaMethod = dynamicExpressionType
.GetMethods(BindingFlags.Public | BindingFlags.Static)
.Where(m => (m.Name == "ParseLambda")
&& (m.GetParameters().Length == 2))
.Single()
.MakeGenericMethod(typeof(T), typeof(Boolean));
var func = (Func<string, object[], Expression<Func<T, bool>>>)
Delegate.CreateDelegate(
typeof(Func<string, object[], Expression<Func<T, bool>>>)
, parseLambdaMethod
);
在Windows底下一直好好的发挥作用
不过最近在mono跑了爆空指针, 或许是类名不同或者压根就没实现吧
不管了, 试着扒出M¥类库的代码看看能不能用吧.
过程略. (反编译,修正编译器生成标识符,切断依赖) 还挺顺利的 乂D
拿去用吧: System.Web.Query.Dynamic.cs.zip 尽管还整理的不够到位
(错误提示口胡和编译经过) 乂D
好吧, 原来dbLinq项目里也有 这玩意 , 用它吧, 这较靠谱
这个月0博文消灭乂D
[原创]基于文件系统的轻量级单机数据库引擎
作者:V君 发布于:2013-11-27 15:16 Wednesday 分类:折腾手记
V君一直在对单机桌面小程序数据存储纠结, 你说.net自带的序列化吧, 由于封装过度不灵活, 实体结构改变的话不晓得会发生什么问题...
你说SqlCe吧, 这货支持Linq2sql确实不错, 但... 这货在建表之后不能改字段名称(至少设计器不行...) 最要命的是平台依赖, 不能跨平台到mono...
再说SQLite吧, 这货足够“适用”了吧? 我的答案是 -- 还不行! 对于V君这个用贯了Linq查询的无脑码农来说, 手写SQL什么的早就不想玩啦... 试过套上 DbLinq 来操作, 结果发现 DbLinq 还有很多不完善的地方, 像子查询什么的直接爆出“未实现” (什么? 你说上SqlServer? 拜托! 一个小程序你扯这么重量级的玩意...)
够了! 自己写一个吧!! 能用Linq的跨平台的单机数据库!!!
blogger
Google Web Translator
热门日志
随机日志
最新日志
最新评论
- V君
@Quartz:(出现)... - Quartz
怎么不见人了呢... - V君
@Soar:DHCP 协议相... - V君
@Soar:当然是非... - Soar
@V君:谢谢 有空... - Soar
搞一个 1230v3+B85... - V君
@Soar:另外,也可... - V君
@Soar:iscsi服务端... - Soar
难怪这么卡,尤其... - Soar
clone了源码,提示...
分类
存档
- 2024年5月(1)
- 2023年7月(1)
- 2023年5月(1)
- 2022年11月(1)
- 2022年10月(1)
- 2022年9月(1)
- 2022年8月(1)
- 2022年7月(1)
- 2022年6月(1)
- 2022年5月(2)
- 2022年4月(1)
- 2022年3月(1)
- 2022年2月(1)
- 2022年1月(1)
- 2021年12月(1)
- 2021年11月(1)
- 2021年10月(1)
- 2021年9月(1)
- 2021年8月(1)
- 2021年7月(1)
- 2021年6月(1)
- 2021年5月(1)
- 2021年4月(1)
- 2021年3月(1)
- 2021年2月(1)
- 2021年1月(1)
- 2020年12月(1)
- 2020年11月(1)
- 2020年10月(2)
- 2020年9月(1)
- 2020年8月(1)
- 2020年7月(1)
- 2020年6月(1)
- 2020年5月(1)
- 2020年4月(2)
- 2020年3月(3)
- 2020年2月(1)
- 2020年1月(1)
- 2019年12月(1)
- 2019年11月(1)
- 2019年10月(1)
- 2019年9月(1)
- 2019年8月(2)
- 2019年7月(1)
- 2019年6月(1)
- 2019年5月(1)
- 2019年4月(1)
- 2019年3月(1)
- 2019年2月(1)
- 2019年1月(2)
- 2018年12月(2)
- 2018年11月(1)
- 2018年10月(3)
- 2018年9月(4)
- 2018年8月(6)
- 2018年7月(4)
- 2018年6月(1)
- 2018年5月(2)
- 2018年4月(2)
- 2018年3月(3)
- 2018年2月(1)
- 2018年1月(1)
- 2017年12月(1)
- 2017年10月(2)
- 2017年9月(1)
- 2017年8月(2)
- 2017年7月(1)
- 2017年6月(5)
- 2017年5月(2)
- 2017年4月(2)
- 2017年3月(3)
- 2017年2月(2)
- 2017年1月(2)
- 2016年12月(3)
- 2016年11月(2)
- 2016年10月(3)
- 2016年9月(4)
- 2016年8月(2)
- 2016年7月(4)
- 2016年6月(3)
- 2016年5月(1)
- 2016年4月(4)
- 2016年3月(3)
- 2016年2月(1)
- 2016年1月(5)
- 2015年12月(4)
- 2015年11月(5)
- 2015年10月(1)
- 2015年9月(6)
- 2015年8月(4)
- 2015年7月(1)
- 2015年6月(6)
- 2015年5月(3)
- 2015年4月(3)
- 2015年3月(2)
- 2015年2月(1)
- 2015年1月(3)
- 2014年12月(1)
- 2014年11月(1)
- 2014年10月(1)
- 2014年9月(3)
- 2014年8月(1)
- 2014年7月(1)
- 2014年6月(1)
- 2014年5月(3)
- 2014年4月(1)
- 2014年3月(1)
- 2014年2月(2)
- 2014年1月(1)
- 2013年12月(2)
- 2013年11月(2)
- 2013年10月(1)
- 2013年9月(3)
- 2013年8月(14)
- 2013年7月(7)
- 2013年4月(1)
- 2013年3月(4)
- 2013年2月(6)
- 2013年1月(6)
- 2012年12月(8)
- 2012年11月(6)