https://avatars.githubusercontent.com/u/18242685

lihuu's blog

Percona XtraBackup

介绍

Persona Xtrabackup 是 MySQL 中的一个免费的热备份工具。它针对 InnoDB 和 XtraDB 提供了无锁的热备份。它有如下几个特点:

  • 可靠的快速备份。
  • 备份时不中断事务处理。
  • 节省硬盘空间和网络带宽。
  • 自动的备份校验。
  • 快速的数据恢复。
  • 支持 InnoDB no-blocking 热备份。
  • 支持增量备份。
  • 支持压缩流式备份到另一台服务器
  • 在不同的服务器中在线迁移表。

前提

需要账号和密码连接服务器

xtrabackup --user=user --password=password --backup --target-dir=/data/backup 除此之外,--port可以指定端口,--socket指定使用 localhost 本地连接的 socket 文件的位置,--host指定 tcp/ip 链接的时候的地址。

MySQL备份方案

备份前准备

创建单独用于备份的用户,并授予相应的权限

create user db_backup@'localhost' identified by 'backup123';
grant select,lock tables,show view,trigger,event on backup_database.* to db_backup@'localhost';
grant reload,Replication client on *.* to db_backup@'localhost';

方案 1:全量逻辑备份(使用 mysqldump,方案 1)

备份

#!/bin/bash
backup_file_name=db_backup_`date '+%Y-%m-%d'`.sql.gz
mysqldump -udb_backup -pbackup123 --single-transaction --flush-logs --master-data=2 backup_database | gzip > $backup_file_name

if [ -e $backup_file_name ] ;then
   echo "Start to copy files"
#   scp $backup_file_name  lihu@ubuntu-vm-02:/home/lihu
else
   echo "No file to copy"
fi

额外的参数 --skip-add-drop-table:生成的备份文件中不要有 drop table 的语句,默认是有的。 --no-data:不导出数据,仅导出表结构 --no-create-info:不导出建表语句,仅导出数据

Powershell配置

Windows10 Powershell 设置

首先 Powershell 的用户配置在用户目录的Documents\WindowsPowerShell\Microsoft.PowerShell_profile.ps1文件中。

美化需要安装一些插件,在 windows 平台上脚本的执行策略必须是RemoteSigned或者Unrestricted,可以使用Get-ExecutePolicy检查 powershell 脚本的执行策略。如果在安装的过程中出现脚本执行策略的问题,可以用Set-ExecutionPolicy设置脚本执行策略,例如 ,可以用如下命令 Set-ExecutionPolicy Unrestricted -Scope CurrentUser将当前用户的脚本执行策略设置为Unrestricted

百度搜索引擎指令

双引号

双引号表示精确搜索,例如,在百度中搜索 java 技术关键字,可以发现 java技术这两个词被分开处理了,即包含 java 和 技术这两个关键字的结果都会返回。

/img/image-20200623130153198.png

如果我们给这两个词加上双引号,就会发现只有这两个词在一起的页面才会被返回,这个就是关键词的精确搜索。

/img/image-20200623130454700.png

site

用来搜索某个域名之下的内容,例如 site:apple.com ipadOS

记录一次在SpringBoot项目中使用log42.yml作为配置文件遇到的问题

首先在 SpringBoot 中集成log4j2还是比较容易的,只需要在 maven 的 pom 文件中修改一下 logging 的依赖然后在resources中添加log4j2相关的配置文件就可以了。 我当时使用的是log4j2.yml格式的配置文件,所以就在mavenpom.xml文件中做了如下的修改:

<dependencies>
...
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter</artifactId>
        <exclusions>
            <exclusion>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-logging</artifactId>
            </exclusion>
        </exclusions>
    </dependency>

    <!--添加log4j2依赖-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-log4j2</artifactId>
    </dependency>

    <!-- 使用log4j2.yml文件格式来配置,需要引入如下的包 -->
    <dependency>
        <groupId>com.fasterxml.jackson.dataformat</groupId>
        <artifactId>jackson-dataformat-yaml</artifactId>
    </dependency>
...
</dependencies>

这个在我当时的项目中是正确运行的。 我后来又创建了一个新的项目,也想用log4j2,就直接复制了上一个项目中配置了,但是在运行的时候发现怎么也加载不了log4j2的配置文件,总是提示ERROR StatusLogger No Log4j 2 configuration file found. Using default configuration (logging only errors to the console), or user programmatically provided ...,但是log4j2的配置文件的确是存在的。 在这样的情况下,日志是无论如何都不会打印出来的,没办法只能加上log4j2.debug属性进行调试,在控制台的日志中我发现了这样一条日志WARN StatusLogger Found configuration file log4j2.yml for inactive ConfigurationFactory org.apache.logging.log4j.core.config.yaml.YamlConfigurationFactory,大体就是YamlConfigurationFactory不是激活状态,就试着全局搜索这句话,找到了如下的代码,

Maven的依赖范围

maven 有以下几种依赖范围:

  • compile编译依赖范围这个是默认的依赖范围,使用这个依赖范围的依赖,对于编译、测试、运行三种 classpath 都有效。

  • test测试依赖范围。这个只对测试 classpath 有效,在编译和项目运行的时候是无法使用此类依赖的,例如 JUnit 依赖。

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <scope>test</scope>
    </dependency>
  • provided已经提供的依赖。这种依赖只对编译和测试的时候有效,运行的时候不会使用这类依赖,例如 servlet-api,在编译和测试项目的时候,都需要使用到这个依赖,在项目运行的时候,容器会提供这个依赖。

Git重写历史

使用git commit --amend修改最后一次提交

如果仅仅是修改最后一次提交的信息,可以直接输入git commit --amend,之后会自动打开一个文本编辑器,直接修改这一条信息就可以了。 /img/1582968318104.png

git rebase -i 使用

修改多个提交信息

Git 中不包含修改历史的工具,可以通过git rebase来间接地实现更改。 例如我想修改最近三次提交历史,可以输入git rebase -i HEAD~3-i表示以交互模式打开进行git rebase,之后会自动打开一个文本编辑器,效果如下图所示: /img/1582968816746.png 我们可以看到前面三行就是最近三次的提交历史(注意这里的显示是按照提交时间正序显示的,我们使用 git log 命令展示的是按照时间倒着显示的),如果我们要修改第一行,就是修改倒数第三次提交,将第一行的**pick修改为edit**,然后保存。 /img/1582969080107.png 然后再执行git commit --amend,会进入和图 1 类似的文本编辑器中,修改信息后保存并关闭文件。这个时候,我们可以使用git status命令查看当前工作区中的状态: /img/1582969386005.png 。我们很容易发现 rebase 还没有完全结束。在这里,我们还需要运行git rebase --continue继续进行 rebase 操作。 下面我们来简单总结一下修改对个提交历史的步骤:

一些比较有用的网站

一个免费的图床网站

路过图床是一个可以提供高速稳定的图片上传和外链服务,目前是免费的,并且也没有流量限制。

网站地址https://imgchr.com/

https://s2.ax1x.com/2020/03/01/32tVeg.jpg

一个可以下载无损音乐的网站

超高无损音乐,这个网站可以下载一些无损格式的音乐,音乐的来源是百度网盘别人分享的。

网站地址https://www.sq688.com/

一个可以生成漂亮的代码的图片的网站

Carbon,这个网站可以帮助我们生成一些漂亮的代码图片。