专栏首页云计算教程系列如何在Ubuntu 14.04上备份OrientDB数据库
原创

如何在Ubuntu 14.04上备份OrientDB数据库

介绍

OrientDB是一个多模型NoSQL数据库,支持图形和文档数据库。它是一个Java应用程序,可以在任何操作系统上运行; 它也完全是ACID投诉,支持多主复制。

OrientDB数据库可以使用备份脚本和命令行界面进行备份,内置支持使用ZIP算法压缩备份文件。

默认情况下,备份OrientDB数据库是一种阻止操作 - 写入数据库的操作将被锁定,直到备份操作结束,但如果操作系统安装在LVM分区方案上,则备份脚本可以执行非阻塞备份。LVM是Linux逻辑卷管理器。

在本文中,您将学习如何在Ubuntu 14.04服务器上备份OrientDB数据库。

要完成本教程,你需要具备以下内容:

  • 一台已经设置好可以使用sudo命令的非root账号的Ubuntu服务器,并且已开启防火墙。没有服务器的同学可以在这里购买,不过我个人更推荐您使用免费的腾讯云开发者实验室进行试验,学会安装后再购买服务器
  • 一个OrienDB数据库,建议您可以直接使用云关系型数据库,云关系型数据库让您在云中轻松部署、管理和扩展的关系型数据库,提供安全可靠、伸缩灵活的按需云数据库服务。腾讯云关系型数据库提供 MySQL、SQL Server、MariaDB、PostgreSQL 数据库引擎,并针对数据库引擎的性能进行了优化。云关系型数据库是一种高度可用的托管服务,提供容灾、备份、恢复、监控、迁移等数据库运维全套解决方案,可将您从耗时的数据库管理任务中解放出来,让您有更多时间专注于您的应用和业务。

先决条件

  • Ubuntu 14.04服务器
  • 在Ubuntu 14.04安装和配置OrientDB

步骤1 - 使用备份脚本备份OrientDB

OrientDB附带一个备份脚本,位于安装目录的bin文件夹中。如果你在Ubuntu 14.04上安装和配置OrientDB,那么安装目录就是/opt/orientdb,所以备份脚本backup.sh应该在/opt/orientdb/bin

在本教程中,在安装目录下创建一个文件夹backup以保存备份。您也可以选择将备份保存在databases文件夹中,该文件夹是应用程序的数据目录。在本教程中,我们将使用backup文件夹,因此创建backup目录:

sudo mkdir -p /opt/orientdb/backup

新创建的文件夹由root拥有,因此我们更改所有权,以便它由orientdb用户拥有。从命令行界面备份时,如果不这样做将导致错误,您将学习如何在步骤2中完成:

sudo chown -R orientdb:orientdb /opt/orientdb/backup

完成后,导航到bin目录:

cd /opt/orientdb/bin

默认情况下,存在一个名为GratefulDeadConcerts的数据库。列出目录databases的内容将显示此默认数据库以及您创建的任何数据库:

ls -l /opt/orientdb/databases

例如,以下显示了GratefulDeadConcerts和一个名为eck的数据库:

Output
total 8
drwxr-xr-x 2 orientdb orientdb 4096 Oct 12 18:36 eck
drwxr-xr-x 2 orientdb orientdb 4096 Oct  4 06:30 GratefulDeadConcerts

在此步骤中,我们将使用备份脚本备份这两个数据库。在这两种情况下,我们都将以admin用户身份执行操作,其密码也是admin。要执行默认数据库的默认(阻止)备份,请键入:

sudo ./backup.sh plocal:../databases/GratefulDeadConcerts admin admin ../backup/gfdc.zip

对于第二个数据库,键入:

sudo ./backup.sh plocal:../databases/eck admin admin ../backup/eck.zip

验证是否已创建备份:

ls -lh ../backup

预期的输出是:

Output
total 236K
-rw-r--r-- 1 root root  17K Oct 13 08:48 eck.zip
-rw-r--r-- 1 root root 213K Oct 13 08:47 gfdc.zip

第2步 - 从控制台备份OrientDB

在此步骤中,我们将从控制台或命令行界面备份其中一个数据库。要进入命令行界面,请键入:

sudo -u orientdb /opt/orientdb/bin/console.sh

输出应该是:

Output
OrientDB console v.2.1.3 (build UNKNOWN@r; 2015-10-04 10:56:30+0000) www.orientdb.com
Type 'help' to display all the supported commands.
Installing extensions for GREMLIN language v.2.6.0
​
orientdb>

接下来,连接到数据库。这里我们使用数据库的默认用户 admin和密码 admin进行连接

connect plocal:/opt/orientdb/databases/eck  admin admin

你会看到这样的输出:

Output
Disconnecting from the database [null]...OK
Connecting to database [plocal:/opt/orientdb/databases/eck] with user 'admin'...OK
orientdb {db=eck}>

现在,将数据库的阻塞备份执行到我们在步骤1中创建的同一备份目录中:

backup database /opt/orientdb/backup/eckconsole.zip

你会看到这样的输出:

Output
Backuping current database to: database /opt/orientdb/backup/eckconsole.zip...
​
- Compressing file name_id_map.cm...ok size=912b compressedSize=250 ratio=73% elapsed=1ms
- Compressing file e.pcl...ok size=65.00KB compressedSize=121 ratio=100% elapsed=13ms
​
...
​
​
- Compressing file orids.cpm...ok size=1024b compressedSize=15 ratio=99% elapsed=1ms
- Compressing file internal.pcl...ok size=129.00KB compressedSize=9115 ratio=94% elapsed=9ms
Backup executed in 0.33 seconds

退出OrientDB数据库提示符:

exit

确认备份到位:

ls -lh ../backup

输出会类似于:

Output
total 256K
-rw-r--r-- 1 orientdb orientdb  17K Oct 13 10:39 eckconsole.zip
-rw-r--r-- 1 orientdb orientdb  17K Oct 13 08:48 eck.zip
-rw-r--r-- 1 orientdb orientdb 213K Oct 13 08:47 gfdc.zip

第3步 - 自动备份OrientDB

OrientDB具有自动备份功能,但默认情况下它处于关闭状态。在此步骤中,我们将启用它,以便每天备份数据库。必须在配置文件中调整自动备份的参数,因此请将其打开:

sudo nano /opt/orientdb/config/orientdb-server-config.xml

使用class =“com.orientechnologies.orient.server.handler.OAutomaticBackup”滚动到handler元素。启用后,其他默认设置将自动备份设置为格林尼治标准时间23:00:00,间隔为4小时。使用下面显示的设置,自动备份将同时进行,但每天只进行一次。

出于测试目的,您可以根据自己的喜好调整firsttime参数:

/opt/orientdb/config/orientdb-server-config.xml
​
<handler class="com.orientechnologies.orient.server.handler.OAutomaticBackup">
<parameters>
<parameter value="true" name="enabled"/>
<parameter value="24h" name="delay"/>
<parameter value="23:00:00" name="firstTime"/>
<parameter value="backup" name="target.directory"/>
<parameter value="${DBNAME}-${DATE:yyyyMMddHHmmss}.zip" name="target.fileName"/>
<parameter value="9" name="compressionLevel"/>
<parameter value="1048576" name="bufferSize"/>
<parameter value="" name="db.include"/>
<parameter value="" name="db.exclude"/>
</parameters>
</handler>
​

完成调整设置后,保存并关闭文件。要应用更改,请停止守护程序:

sudo service orientdb stop

然后重新启动它:

sudo service orientdb start

在设定的时间之后,通过查看新backup目录来验证它是否有效:

ls -lh /opt/orientdb/bin/backup

输出应该类似于:

Output
total 236K
-rw-r--r-- 1 orientdb orientdb  17K Oct 13 16:00 eck-20151013160001.zip
-rw-r--r-- 1 orientdb orientdb 213K Oct 13 16:00 gratefulnotdead-20151013160002.zip

在箱外,默认数据库GratefulDeadConcert不会被自动备份工具备份,因此如果您没有看到它列出,那就是一个功能。

结论

您刚刚学习了可用于备份OrientDB数据库的所有非编程步骤。

想要了解更多关于备份OrientDB数据库的相关教程,请前往腾讯云+社区学习更多知识。

参考文献:《How To Back Up Your OrientDB Databases on Ubuntu 14.04》

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 在你的电脑上运行Kubernetes

    Kubernetes 是编配平台的首选。在开发过程中,您不妨在个人电脑上运行 Kubernetes,以便在本地启动和调试应用程序。本文提供了两种在 Mac OS...

    小铁匠米兰的v
  • 如何在Nginx配置Gzip

    网站加载的速度取决于浏览器必须下载的所有文件的大小。减少要传输的文件的大小可以使网站不仅加载更快,而且对于那些宽带是按量计费的人来说也更友好。

    小铁匠米兰的v
  • 如何在Ubuntu 14.04上安装和使用Docker Compose

    Docker是一个很棒的工具,但要真正充分发挥其潜力,最好是应用程序的每个组件都在自己的容器中运行。对于具有大量组件的复杂应用程序,编排所有容器以一起启动和关闭...

    小铁匠米兰的v
  • shell(一)

    Be kind; everyone you meet is fighting a hard battle.

    小闫同学啊
  • Oracle 备份恢复概念

    数据库维护中,备份或恢复是重中之重的问题。尽管很多时候数据库系统运行缓慢,但对数据库数据的丢失而言,显然后者损失的代价是

    Leshami
  • Java--StringBuilder,StringBuffer,StringJoiner

    开始自己的一个半年计划,也就是java相关常用类的源码阅读,通过阅读查漏补缺,加深基础知识的运用与理解.

    屈定
  • ASCII,Unicode和UTF-8

    一、ASCII码 我们知道,计算机内部,所有信息最终都是一个二进制值。每一个二进制位(bit)有0和1两种状态,因此八个二进制位就可以组合出256种状态,这被称...

    Angel_Kitty
  • Oracle数据恢复、数据库恢复、灾难恢复专题

    原文链接:http://www.eygle.com/blog/special/oracle_recovery.html

    数据和云01
  • 字符编码那点事:快速理解ASCII、Unicode、GBK和UTF-8

    原作者:阮一峰(ruanyifeng.com),现重新整理发布,感谢原作者的无私分享。

    JackJiang
  • 字符编码笔记

    字符编码笔记:ASCII,Unicode和 UTF-8 1. ASCII码 我们知道,在计算机内部,所有的信息最终都表示为一个二进制的字符串。每一个二 进制位...

    wangxl

扫码关注云+社区

领取腾讯云代金券