有没有简单的方法来保存所有表,变量和函数,然后将它们重新加载到另一个kdb +实例中?例如,假设我的机器设置为每周重新启动,但是我想在重新启动之前重新加载在我的kdb +会话中的所有内容。保存KDB +实例的所有表,变量和函数,然后重新加载
谢谢。
有没有简单的方法来保存所有表,变量和函数,然后将它们重新加载到另一个kdb +实例中?例如,假设我的机器设置为每周重新启动,但是我想在重新启动之前重新加载在我的kdb +会话中的所有内容。保存KDB +实例的所有表,变量和函数,然后重新加载
谢谢。
使用set/get将状态保存到文件。这仅限于小型工作区。
>q
KDB+ 3.4 2016.06.14 Copyright (C) 1993-2016 Kx Systems
q)a:1
q)t:([] b:til 100)
q)s:select from t where b<5
q)`:session.bin set get `.
`:session.bin
q)\\
>q
KDB+ 3.4 2016.06.14 Copyright (C) 1993-2016 Kx Systems
q)`. set get `:session.bin
`.
q)a
1
q)s
b
-
0
1
2
3
4
日志和快照是一种替代方案: http://www.timestored.com/kdb-guides/kdb-command-line-options#kdb-logging-replication
如果你想要的东西开箱维持可变状态(表/类型的字典/列表/原子),然后看看http://code.kx.com/q/cookbook/logging/
/cmdline startup
q db_main -l -p 8090
/To store state before the restart, modify .z.exit to flush to the qdb file
.z.exit:{value"\\l"}
但是这不包括功能,但理想情况下这些不应该改变。
如果你真的需要保存这些,你可以看看把所有的名字空间保存到磁盘。
.z.exit:{`:/tmp/ns set get each {x!x}`$".",/:string key`}
/on startup
{{y set x[y]}[x;]each key x} `.q`.Q _ get `:/tmp/ns
问候,
康纳
如果我有多个工作区.. – shivam
这样,如果你想保存多个命名空间的工作。 http://stackoverflow.com/a/38528576/2039505 –