2018年6月

select(index, ...)

如果index是正数,那么返回从左边第index个到最右边的参数;
如果index是负数,那么返回从右边第index个到最左边的参数;
如果index是字符串"#", 那么返回可变参数...的参数个数
例如:

function test(...)
    print(select("#", ...))
    -- 输出为:
    -- 4

    for i=1, select("#", ...) do
        print(select(i, ...))
    end
    -- 输出为:
    -- 1    2    3    4
    -- 2    3    4
    -- 3    4
    -- 4

    for i=1, select("#", ...) do
        print(select(-i, ...))
    end
    -- 输出为:
    -- 4
    -- 3    4
    -- 2    3    4
    -- 1    2    3    4
end

test(1, 2, 3, 4)

ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

information_schema库中有三个关于锁的表:

  • innodb_trx ## 当前运行的所有事务
  • innodb_locks ## 当前出现的锁
  • innodb_lock_waits ## 锁等待的对应关系

解决办法

select * from information_schema.innodb_trx;
select * from information_schema.innodb_locks;
select * from information_schema.innodb_lock_waits;
-- 找到一直没有提交的事务
kill <trx_mysql_thread_id>

客户端配置

生成密钥文件

使用ssh-keygen命令在客户端电脑上生成公钥和私钥,根据提示操作,保存到$HOME/.ssh/目录, 例如生成的文件为:xxx_rsa, xxx_rsa.pub

ssh-keygen -t rsa -b 4096 -C "your_email@example.com"

<br/>

配置登录的key

编辑~/.ssh/config, 按如下格式编辑

Host <hostname>
    Hostname <hostname>
    User <username>
    Port <port>
    IdentityFile ~/.ssh/xxx_rsa

<br/>

SSH Key认证
ssh <hostname>

<br/>

服务端配置

先以Root用户登录
在authorized_keys文件尾,增加SSH KEY

vi ~/.ssh/authorized_keys

编辑ssh配置文件

vi /etc/ssh/sshd_config

内容修改为:

RSAAuthentication yes
StrictModes no
PubkeyAuthentication yes
AuthorizedKeysFile .ssh/authorized_keys
PasswordAuthentication no

重启SSH

systemctl restart sshd.service

重启好后,就可以使用上面的ssh <hostname>登录服务器了.

Luajit 是针对Lua开发的一款即时编译器, 提供了FFI库, 可以方便使用C接口的动态库.

先准备一个C语言的库
mytest.c

int add(int x, int y)
{
    return x + y;
}

编译动态库文件libmytest.so

g++ mylib.c --shared -o libmytest.so

Lua文件test.lua

local ffi = require("ffi")
local mytest = ffi.load('mytest')

ffi.cdef[[
int add(int x, int y);
]]

local result = mytest.add(1, 2)

print(result)

执行test.lua

luajit test.lua

如果出现动态库找不到的情况下,可以执行下面的命令:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:<动态库所有目录>

查看远程跟踪的分支

git branch -vv

修改远程跟踪的分支

# git版本: 1.8+
# 设置当前分支跟踪为origin/dev
git branch --set-upstream-to=origin/dev

# 设置本地分支dev1跟踪为origin/dev
git branch --set-upstream-to=origin/dev dev1

# 简化的命令
git branch -u origin/dev
git branch -u origin/dev dev1

# git版本: 1.7
git branch --set-upstream dev origin/dev