修改软件源为国内加速镜像

通用
阿里云镜像 http://mirrors.aliyun.com
网易镜像 http://mirrors.163.com
搜狐镜像 http://mirrors.sohu.com

教育网
清华大学开源软件镜像 https://mirrors.tuna.tsinghua.edu.cn
中国科学技术大学开源软件镜像 https://mirrors.ustc.edu.cn

更多源

各系统软件源修改方法
CentOS

# 系统代号     版本
# squeeze     6.x
# wheezy      7.x
# jessie      8.x

# 备份原文件
mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

# 下载新的CentOS-Base.repo 到/etc/yum.repos.d/

# CentOS 5
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-5.repo

# CentOS 6
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-6.repo

# CentOS 7
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

# 生成缓存
yum makecache

Debina

# 备份原文件
mv /etc/apt/sources.list /etc/apt/sources.list.bak

# 修改为阿里云的镜像源
cat > /etc/apt/sources.list << END
deb http://mirrors.aliyun.com/debian/ jessie main non-free contrib
deb http://mirrors.aliyun.com/debian/ jessie-proposed-updates main non-free contrib
deb-src http://mirrors.aliyun.com/debian/ jessie main non-free contrib
deb-src http://mirrors.aliyun.com/debian/ jessie-proposed-updates main non-free contrib
END
# 更新源列表信息 apt-get update

Ubuntu

# 系统代号      版本    LTS
# precise     12.04   true
# trusty      14.04   true
# vivid       15.04
# xenial      16.04   true
# zesty       17.04

# 备份原文件
mv /etc/apt/sources.list /etc/apt/sources.list.bak

# 修改为阿里云的镜像源
cat > /etc/apt/sources.list << END
deb http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-proposed main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ trusty-backports main restricted universe multiverse
END

# 更新源列表信息
apt-get update

Alpine

# 备份原始文件
cp /etc/apk/repositories /etc/apk/repositories.bak

# 修改为国内镜像源
echo "https://mirrors.aliyun.com/alpine/latest-stable/main/" > /etc/apk/repositories

jQuery放大镜CloudZoom插件分析,反编译

1. 分析,打开CloudZoom.js,发现是十六进制混淆:

console.log('\x46\x75\x6E\x63\x74\x69\x6F\x6E');
console.log('\x72\x65\x76\x65\x72\x73\x65');
console.log('\x6A\x6F\x69\x6E');

2. 反编译:

var zoom_str = ['...'];
(new Function(zoom_str.reverse().join('')))();
console.log(zoom_str.reverse().join(''));

3. Enjoy it…

附上已破解的源文件:cloudzoom

全局唯一id生成

<?php
/**
 * 全局唯一id生产类
 * https://segmentfault.com/a/1190000007769660
 * 基于Twitter的SnowFlake算法改造
 * twitter的结构:
 * 64bit = 1bit为空缺 + 41bit毫秒时间戳 + 10bit机器id + 12bit自增id
 * 当前结构 **** 最多支持128项业务
 * 64bit = 1bit空缺 + 7bit业务编号(128项业务) + 39bit毫秒时间戳(与2017-06-01的差值) + 5bit机器id(32台) + 4bit一级随机数 + 4bit二级随机数 + 4bit三级随机数
 */

$machineid_file = "/data/machineid.txt";
if (file_exists($machineid_file)) {
    $machine_id = intval(file_get_contents($machineid_file));
    if ($machine_id > 31 || $machine_id < 0) {
        $machine_id = 0;
    }
} else {
    $machine_id = 0;
}

define('MACHINE_ID', $machine_id);

class BusinessIdHelper
{

    public static $start_stamp = 1496246400000; // 2017-06-01 00:00:00的毫秒级时间戳
    public static $max_rand = 15;

    public static function generateId($business_id)
    {
        // 1bit - 头部空缺
        $head_bin = str_pad(decbin(0), 1, "0", STR_PAD_LEFT);

        // 7bit - 7bit业务编号(最多128项业务)
        $business_id_bin = str_pad(decbin($business_id), 7, "0", STR_PAD_LEFT);

        // 39bit - (now - $start_stamp)的毫秒级时间戳差值
        $now_stamp = floor(microtime(true) * 1000);
        $diff_stamp_bin = str_pad(decbin($now_stamp - self::$start_stamp), 39, "0", STR_PAD_LEFT);

        // 5bit - 32台机器
        $machine_id_bin = str_pad(decbin(MACHINE_ID), 5, "0", STR_PAD_LEFT);

        // 4bit - 4位随机数(0 ~ 15)
        // 一级
        $random1 = mt_rand(0, self::$max_rand);
        $random1_bin = str_pad(decbin($random1), 4, "0", STR_PAD_LEFT);
        // 二级
        $random2 = mt_rand(0, self::$max_rand);
        $random2_bin = str_pad(decbin($random2), 4, "0", STR_PAD_LEFT);
        // 三级
        $random3 = mt_rand(0, self::$max_rand);
        $random3_bin = str_pad(decbin($random3), 4, "0", STR_PAD_LEFT);

        // 链接二进制串
        $pack_data = $head_bin . $business_id_bin . $diff_stamp_bin . $machine_id_bin . $random1_bin . $random2_bin . $random3_bin;

        /*
        var_dump($business_id);
        var_dump($now_stamp);
        var_dump(MACHINE_ID);
        var_dump($pid);
        var_dump($pack_data);
        */

        return bindec($pack_data);
    }

    public static function parseId($id)
    {
        // 数据不满64位的,需要补齐
        $data_bin = str_pad(decbin($id), 64, "0", STR_PAD_LEFT);

        $head_bin = substr($data_bin, 0, 1);

        $business_id_bin = substr($data_bin, 1, 7);
        $diff_stamp_bin = substr($data_bin, 8, 39);
        $machine_id_bin = substr($data_bin, 47, 5);
        $random1_bin = substr($data_bin, 52, 4);
        $random2_bin = substr($data_bin, 56, 4);
        $random3_bin = substr($data_bin, 60, 4);

        $head = bindec($head_bin);
        $business_id = bindec($business_id_bin);
        $diff_stamp = bindec($diff_stamp_bin);
        $machine_id = bindec($machine_id_bin);
        $random1 = bindec($random1_bin);
        $random2 = bindec($random2_bin);
        $random3 = bindec($random3_bin);

        $stamp = self::$start_stamp + $diff_stamp;  // 毫秒

        $data = [
            'head' => $head,
            'business_id' => $business_id,
            'stamp' => $stamp,  // 毫秒
            'machine_id' => $machine_id,
            'random1' => $random1,
            'random2' => $random2,
            'random3' => $random3,
        ];

        return $data;
    }

}
?>

 

OS X的权限系统

OS X的权限系统
OS X的内核XNU,来源于Mach、BSD、IOKit,其权限管理系统类似BSD。OS X中内置了staff, wheel, admin这几种常见的用户组。
一、staff – 所有用户都属于staff组,对~/*拥有rwx权限,其他路径通常只有r或rx权限。
二、admin – 所有用户都属于admin组,可以通过sudo执行root用户的命令,而无需知道root密码。
三、wheel – 这个组里只有root一个用户,是root的专属用户组。

因为默认创建的用户属于admin组,可以通过这个用户的密码执行sudo,那么如果这个用户的密码被盗,黑客就相当于有了root的权限,可以对系统做任意修改。而通过Rootless的限制,即使root用户,也无法修改以上特定目录。

/usr/local在EI Capitan之前是属于当前用户:admin的,但在Rootless模式下,这个路径的属主变为了root:wheel,这样如brew之类的包管理器就无法往/usr/local中写入啦。要继续使用brew安装Packages,请先执行以下命令:

sudo chown -R $(whoami):admin /usr/local

把/usr/local的属主重新修改为当前用户:admin。

管道符sort

sort
sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式:

sort [-bcfMnrtk][源文件][-o 输出文件]

补充说明:sort可针对文本文件的内容,以行为单位来排序。

参数:
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已经按照顺序排序。
-f 排序时,忽略大小写字母。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-o <输出文件> 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t <分隔字符> 指定排序时所用的栏位分隔字符。
-k 选择以哪个区间进行排序。
常用命令:| sort -rn

Linux磁盘或文件大小查看

df 查看磁盘空间使用情况
du 查看各目录或文件所占空间

经常需要查看Linux文件大小,只记得df -h,经常忘了du -h,故此总结记录。

df
1. 命令格式:
df [选项] [文件]
2. 命令功能:
显示指定磁盘文件的可用空间。如果没有文件名被指定,则所有当前被挂载的文件系统的可用空间将被显示。默认情况下,磁盘空间将以 1KB为单位进行显示,除非环境变量 POSIXLY_CORRECT 被指定,那样将以512字节为单位进行显示
3. 命令参数:
必要参数:
-a 全部文件系统列表
-h 方便阅读方式显示
-H 等于“-h”,但是计算式,1K=1000,而不是1K=1024
-i 显示inode信息
-k 区块为1024字节
-l 只显示本地文件系统
-m 区块为1048576字节
–no-sync 忽略 sync 命令
-P 输出格式为POSIX
–sync 在取得磁盘信息前,先执行sync命令
-T 文件系统类型
选择参数:
–block-size=<区块大小> 指定区块大小
-t <文件系统类型> 只显示选定文件系统的磁盘信息
-x <文件系统类型> 不显示选定文件系统的磁盘信息
–help 显示帮助信息
–version 显示版本信息
常用命令:df -hi

du
1.命令格式:
du [选项][文件]
2.命令功能:
显示每个文件和目录的磁盘使用空间。
3.命令参数:
-a或-all 显示目录中个别文件的大小。
-b或-bytes 显示目录或文件大小时,以byte为单位。
-c或–total 除了显示个别目录或文件的大小外,同时也显示所有目录或文件的总和。
-k或–kilobytes 以KB(1024bytes)为单位输出。
-m或–megabytes 以MB为单位输出。
-s或–summarize 仅显示总计,只列出最后加总的值。
-h或–human-readable 以K,M,G为单位,提高信息的可读性。
-x或–one-file-xystem 以一开始处理时的文件系统为准,若遇上其它不同的文件系统目录则略过。
-L <符号链接>或–dereference<符号链接> 显示选项中所指定符号链接的源文件大小。
-S或–separate-dirs 显示个别目录的大小时,并不含其子目录的大小。
-X <文件>或–exclude-from=<文件> 在<文件>指定目录或文件。
–exclude=<目录或文件> 略过指定的目录或文件。
-D或–dereference-args 显示指定符号链接的源文件大小。
-H或–si 与-h参数相同,但是K,M,G是以1000为换算单位。
-l或–count-links 重复计算硬件链接的文件。
常用命令:du -a

mysql 数据库表及数据导入导出方法总结

前言
由于公司的MySQL是搭建在服务器上,为了避免对服务器进行直接改动,想远程导出和导入MySQL的数据库表结构及数据进行操作, 刚好Mysql本身提供了命令行导出工具Mysqldump和Mysql Source导入命令进行SQL数据导入导出工作,通过Mysql命令行导出工具Mysqldump命令能够将Mysql数据导出为文本格式(txt)的SQL文件,通过Mysql Source命令能够将SQL文件导入Mysql数据库中,下面通过Mysql导入导出SQL实例详解Mysqldump和Source命令的用法

数据库表及数据导出
需求说明是要希望导出整个数据库结构脚本,而MySQL提供的Mysqldump命令刚好可达到此目的而且还可以将数据库中的数据也一并导出

mysqldump导出语法以及实践
1. mysqldump -h{hostname} [-P{port}] -u{username} -p{password} [--default-character-set=charset] database [tablename]
2. # 注:-h和[hostname]之间并没有空格相连, 后同之, []扩起来的为可选项, 可不填

  • hostname表示主机名, 本地则填localhost, 远程则填写你的远程IP, 如192.168.0.3;
  • username是你的MySQL登录帐号, password则是登录密码;
  • default-character-set则是你的字符集编码, 如gb2312、gbk和utf8(没有横杠哦);
  • dbname是你的数据库名称, tablename是你的表名, 假如你不填写tablename的话则默认导出所有的表。

通过上面的导出语句, 将会在当前目录下面创建一个crm_adapter_db.sql脚本文件, 这个脚本文件是可运行的, 它包含了crm_adapter数据库中所有数据表的建表细节以及其所有的数据。这就是导出命令的特点,它不但会导出数据,还会导出表或者数据库的结构信息。另外如果不带”> {you file path}”这一部分路径信息,mysqldump导出命令或把内容打印在terminal命令界面上。

数据库表及数据导入
数据库表及数据导入可用mysqldump 和source 两种方法来操作

通过mysqldump 工具导入
mysqldump -h{hostname} [-P{port}] -u{username} -p{password} [–default-character-set=charset] database [tablename] < {you file path}
mysqldump -h192.168.0.3 -P3308 -uroot -p123456 databasename < ./crm_adapter_db.sql

通过source 命令导入
source命令导入不同于mysqldump, 它是一个SQL命令, 必须登录进入MySQL在命令行那里才可以运行, 而mysqldump实则是一个管理工具,无须登入MySQ在命令行那里运行,只须在命令行下运行即可。先登入MySQL:
mysql -h{hostname} [-p{port}] -u{username} -p{password}
举例, 我们登入一个远程MySQL可以用下面的命令
mysql -h192.168.0.3 -unikey -p123456
登入之后,进入我们要作用的数据库,
mysql > use my_crm_adapter;
然后我们可以使用source命令来运行前面导出的sql脚本实现数据的导入,
mysql > source ./crm_adapter_db.sql;

建议优先使用source 命令来导入数据

mysqldump使用总结

导出所有库
系统命令行
mysqldump -uusername -ppassword --all-databases > all.sql

导入所有库
mysql命令行
mysql>source all.sql;

导出某些库
系统命令行
mysqldump -uusername -ppassword --databases db1 db2 > db1db2.sql

导入某些库
mysql命令行
mysql>source db1db2.sql;

导入某个库
系统命令行
mysql -uusername -ppassword db1 < db1.sql;
或mysql命令行
mysql>source db1.sql;

导出某些数据表
系统命令行
mysqldump -uusername -ppassword db1 table1 table2 > tb1tb2.sql

导入某些数据表
系统命令行
mysql -uusername -ppassword db1 < tb1tb2.sql
或mysql命令行
mysql>user db1;
mysql>source tb1tb2.sql;

mysqldump字符集设置
mysqldump -uusername -ppassword –default-character-set=gb2312 db1 table1 > tb1.sql
mysqldump客户端可用来转储数据库或搜集数据库进行备份或将数据转移到另一个sql服务器(不一定是一个mysql服务器)。转储包含创建表和/或装载表的sql语句。
如果在服务器上进行备份,并且表均为myisam表,应考虑使用mysqlhotcopy,因为可以更快地进行备份和恢复。
有3种方式来调用mysqldump:
系统命令行
mysqldump [options] db_name [tables]
# 或
mysqldump [options] ---database db1 [db2 db3...]
# 或
mysqldump [options] --all--database

如果没有指定任何表或使用了--database--all–database选项,则转储整个数据库。
要想获得你的版本的mysqldump支持的选项,执行mysqldump --help
如果运行mysqldump没有–quick或–opt选项,mysqldump在转储结果前将整个结果集装入内存。如果转储大数据库可能会出现问题。该选项默认启用,但可以用–skip-opt禁用。
如果使用最新版本的mysqldump程序生成一个转储重装到很旧版本的mysql服务器中,不应使用–opt或-e选项。
mysqldump支持下面的选项:
--help 或-?
显示帮助消息并退出。
--add-drop--database
在每个create database语句前添加drop database语句。
--add-drop-tables
在每个create table语句前添加drop table语句。
--add-locking
用lock tables和unlock tables语句引用每个表转储。重载转储文件时插入得更快。
--all--database 或 -a
转储所有数据库中的所有表。与使用—database选项相同,在命令行中命名所有数据库。
--allow-keywords
允许创建关键字列名。应在每个列名前面加上表名前缀。
--comments[={0|1}]
如果设置为0, 禁止转储文件中的其它信息, 例如程序版本, 服务器版本和主机。--skip—comments与--comments=0的结果相同。 默认值为1,即包括额外信息。
--compact
产生少量输出。该选项禁用注释并启用--skip-add-drop-tables、--no-set-names、--skip-disable-keys和--skip-add-locking选项。
--compatible=name
产生与其它数据库系统或旧的mysql服务器更兼容的输出。值可以为ansi、mysql323、mysql40、postgresql、oracle、mssql、db2、maxdb、no_key_options、no_tables_options或者no_field_options。要使用几个值,用逗号将它们隔开。这些值与设置服务器sql模式的相应选项有相同的含义。该选项不能保证同其它服务器之间的兼容性。它只启用那些目前能够使转储输出更兼容的sql模式值。例如,–compatible=oracle 不映射oracle类型或使用oracle注释语法的数据类型。
--complete-insert 或 -c
使用包括列名的完整的insert语句。
--compress 或-c
压缩在客户端和服务器之间发送的所有信息(如果二者均支持压缩)。
--create-option
在create table语句中包括所有mysql表选项。
--database 或 -b
转储几个数据库。通常情况, mysqldump将命令行中的第1个名字参量看作数据库名,后面的名看作表名。使用该选项,它将所有名字参量看作数据库名。create database if not exists db_name和use db_name语句包含在每个新数据库前的输出中。
--debug[=debug_options] 或-# [debug_options]
写调试日志。debug_options字符串通常为’d:t:o,file_name’。
--default-character-set=charset
使用charsetas默认字符集。如果没有指定,mysqldump使用utf8。
--delayed-insert
使用insert delayed语句插入行。
--delete-master-logs
在主复制服务器上,完成转储操作后删除二进制日志。该选项自动启用--master-data。
--disable-keys 或 -k
对于每个表,用/!40000 alter table tbl_name disable keys /;和/!40000 alter table tbl_name enable keys /;语句引用insert语句。这样可以更快地装载转储文件,因为在插入所有行后创建索引。该选项只适合myisam表。
--extended-insert 或 -e
使用包括几个values列表的多行insert语法。这样使转储文件更小,重载文件时可以加速插入。
--fields-terminated-by=...,--fields-enclosed-by=...,--fields-optionally-enclosed-by=...,--fields-escaped-by=...,--行-terminated-by=...
这些选项结合-t选项使用,与load data infile的相应子句有相同的含义。
--first-slave 或 -x
不赞成使用,现在重新命名为–lock-all-tables。
--flush-logs 或 -f
开始转储前刷新mysql服务器日志文件。该选项要求reload权限。请注意如果结合--all--database(或-a)选项使用该选项,根据每个转储的数据库刷新日志。例外情况是当使用--lock-all-tables或--master-data的时候:在这种情况下, 日志只刷新一次, 在所有表被锁定后刷新。如果你想要同时转储和刷新日志,应使用--flush-logs连同--lock-all-tables或--master-data。
--force或-f
在表转储过程中, 即使出现sql错误也继续。
--host=host_name 或 -h host_name
从给定主机的mysql服务器转储数据。默认主机是localhost。
--hex-blob
使用十六进制符号转储二进制字符串列(例如,’abc’ 变为0x616263)。影响到的列有binary、varbinary、blob。
--lock-all-tables 或 -x
所有数据库中的所有表加锁。在整体转储过程中通过全局读锁定来实现。该选项自动关闭--single-transaction和--lock-tables。
--lock-tables 或-l
开始转储前锁定所有表。用read local锁定表以允许并行插入myisam表。对于事务表例如innodb和bdb,--single-transaction是一个更好的选项,因为它不根本需要锁定表。请注意当转储多个数据库时,–lock-tables分别为每个数据库锁定表。因此,该选项不能保证转储文件中的表在数据库之间的逻辑一致性。不同数据库表的转储状态可以完全不同。
--master-data[=value]
该选项将二进制日志的位置和文件名写入到输出中。该选项要求有reload权限,并且必须启用二进制日志。如果该选项值等于1,位置和文件名被写入change master语句形式的转储输出,如果你使用该sql转储主服务器以设置从服务器,从服务器从主服务器二进制日志的正确位置开始。如果选项值等于2,change master语句被写成sql注释。如果value被省略,这是默认动作。
--master-data选项启用--lock-all-tables,除非还指定--single-transaction(在这种情况下,只在刚开始转储时短时间获得全局读锁定。又见--single-transaction。在任何一种情况下,日志相关动作发生在转储时。该选项自动关闭--lock-tables。
--no-create-db 或 -n
该选项禁用create database /!32312 if not exists/ db_name语句,如果给出—database或–all–database选项,则包含到输出中。
--no-create-info 或 -t
不写重新创建每个转储表的create table语句。
--no-data 或 -d
不写表的任何行信息。如果你只想转储表的结构这很有用。
--opt
该选项是速记;等同于指定 –add-drop-tables–add-locking –create-option –disable-keys–extended-insert –lock-tables –quick –set-charset。它可以给出很快的转储操作并产生一个可以很快装入mysql服务器的转储文件。该选项默认开启,但可以用–skip-opt禁用。要想只禁用确信用-opt启用的选项,使用–skip形式;例如,–skip-add-drop-tables或–skip-quick。
–password[=password],-p[password]
连接服务器时使用的密码。如果你使用短选项形式(-p),不能在选项和密码之间有一个空格。如果在命令行中,忽略了–password或-p选项后面的 密码值,将提示你输入一个。
–port=port_num,-p port_num
用于连接的tcp/ip端口号。
–protocol={tcp | socket | pipe | memory}
使用的连接协议。
–quick,-q
该选项用于转储大的表。它强制mysqldump从服务器一次一行地检索表中的行而不是检索所有行并在输出前将它缓存到内存中。
–quote-names,-q
用”`“字符引用数据库、表和列名。如果服务器sql模式包括ansi_quotes选项,用”字符引用名。默认启用该选项。可以用–skip-quote-names禁用,但该选项应跟在其它选项后面,例如可以启用–quote-names的–compatible。
–result-file=file,-r file
–socket=path,-s path
当连接localhost(为默认主机)时使用的套接字文件。
–skip–comments
参见—comments选项的描述。
–tab=path,-t path
产生tab分割的数据文件。对于每个转储的表,mysqldump创建一个包含创建表的create table语句的tbl_name.sql文件,和一个包含其数据的tbl_name.txt文件。选项值为写入文件的目录。
默认情况,.txt数据文件的格式是在列值和每行后面的新行之间使用tab字符。可以使用–fields-xxx和–行–xxx选项明显指定格式。
注释:该选项只适用于mysqldump与mysqld服务器在同一台机器上运行时。你必须具有file权限,并且服务器必须有在你指定的目录中有写文件的许可。
–tables
覆盖—database或-b选项。选项后面的所有参量被看作表名。
–triggers
为每个转储的表转储触发器。该选项默认启用;用–skip-triggers禁用它。
–tz-utc
在转储文件中加入set time_zone=’+00:00’以便timestamp列可以在具有不同时区的服务器之间转储和重载。(不使用该选项,timestamp列在具有本地时区的源服务器和目的服务器之间转储和重载)。–tz-utc也可以保护由于夏令时带来的更改。–tz-utc默认启用。要想禁用它,使用–skip-tz-utc。该选项在mysql 5.1.2中加入。
–where=’where-condition’, -w ‘where-condition’
只转储给定的where条件选择的记录。请注意如果条件包含命令解释符专用空格或字符,一定要将条件引用起来。
例如:
"--where=user='jimf'" "-wuserid>1" "-wuserid<1" –xml,-x 将转储输出写成xml。 还可以使用–var_name=value选项设置下面的变量: max_allowed_packet 客户端/服务器之间通信的缓存区的最大大小。最大为1gb。 net_buffer_length 客户端/服务器之间通信的缓存区的初始大小。当创建多行插入语句时(如同使用选项–extended-insert或–opt),mysqldump创建长度达net_buffer_length的行。如果增加该变量,还应确保在mysql服务器中的net_buffer_length变量至少这么大。 还可以使用–set-variable=var_name=value或-o var_name=value语法设置变量。然而,现在不赞成使用该语法。 mysqldump最常用于备份一个整个的数据库: mysqldump –opt db_name > backup-file.sql
可以这样将转储文件读回到服务器:
mysql db_name < backup-file.sql 或: mysql -e “source /path-to–backup/backup-file.sql” db_name mysqldump也可用于从一个mysql服务器向另一个服务器复制数据时装载数据库: mysqldump –opt db_name | mysql –host=remote_host -c db_name 可以用一个命令转储几个数据库: mysqldump —database db_name1 [db_name2 …] > my_databases.sql
如果想要转储所有数据库,使用–all–database选项:
mysqldump –all-databases > all_databases.sql
如果表保存在innodb存储引擎中,mysqldump提供了一种联机备份的途径(参见下面的命令)。该备份只需要在开始转储时对所有表进行全局读锁定(使用flush tables with read lock)。获得锁定后,读取二进制日志的相应内容并将锁释放。因此如果并且只有当发出flush…时正执行一个长的更新语句,mysql服务器才停止直到长语句结束,然后转储则释放锁。因此如果mysql服务器只接收到短(“短执行时间”)的更新语句,即使有大量的语句,也不会注意到锁期间。
mysqldump –all-databases –single-transaction > all_databases.sql
对于点对点恢复(也称为“前滚”,当你需要恢复旧的备份并重放该备份以后的更改时),循环二进制日志或至少知道转储对应的二进制日志内容很有用:
mysqldump –all-databases –master-data=2 > all_databases.sql

mysqldump –all-databases –flush-logs –master-data=2 > all_databases.sql
如果表保存在innodb存储引擎中,同时使用–master-data和–single-transaction提供了一个很方便的方式来进行适合点对点恢复的联机备份。