ambari-server启动异常,报错:ambari_commons.exceptions.FatalException

ambari-server启动异常,报错:ambari_commons.exceptions.FatalException,第1张

因公司服务器迁移,需要将服务器断电,重启服务器后,ambari-server无法自启动,于是手动启动ambari-server,报错如下:

[root@devhadoop ~]# ambari-server start

Using python  /usr/bin/python

Starting ambari-server

Traceback (most recent call last):

 File "/usr/sbin/ambari-serverpy", line 36, in

   from ambari_serverdbConfiguration import DATABASE_NAMES,LINUX_DBMS_KEYS_LIST

 File"/usr/lib/python26/site-packages/ambari_server/dbConfigurationpy",line 28, in

   from ambari_serverserverConfiguration importdecrypt_password_for_alias, get_ambari_properties, get_is_secure, \

 File"/usr/lib/python26/site-packages/ambari_server/serverConfigurationpy",line 587, in

   configDefaults = ServerConfigDefaults()

 File"/usr/lib/python26/site-packages/ambari_server/serverConfigurationpy",line 500, in __init__

   super(ServerConfigDefaultsLinux, self)__init__()

 File"/usr/lib/python26/site-packages/ambari_server/serverConfigurationpy",line 384, in __init__

   selfcheck_if_directories_writable([selfOUT_DIR, selfPID_DIR])

  File"/usr/lib/python26/site-packages/ambari_server/serverConfigurationpy",line 436, in check_if_directories_writable

    raise FatalException(-1, "Unable toaccess {0} directory Confirm the directory is created and is writable byAmbari Server user account '{1}'"format(directory, getpassgetuser()))

ambari_commonsexceptionsFatalException: "Fatalexception: Unable to access  directoryConfirm the directory is created and is writable by Ambari Server user account'root', exit code -1"

 

试了好几次ambari-server start命令,都不好使;重启服务器几次,也仍然是不行。
通过执行以下命令,查看ambari-server的执行用户:

#grep'ambari-serveruser' /etc/ambari-server/conf/ambariproperties

ambari-serveruser=root
发现,在该台服务器 上执行该命令返回为空,查看ambariproperties 文件内容,该文件居然是空文件,没有任何内容;于是查看其他ambari 正常的服务器 上的该文件,发现并不是空的,查询结果返回的是root 。这就表明,很可能是因为该文件内容的缺失,导致的该情况!!!这可是一个令人兴奋的发现啊。

于是直接从好用的ambari-server上,将该文件复制到该台服务器上,重新启动ambari-server,果然,可以正常启动ambari-server了,太神奇了!!!不过,不知道为什么这个文件内容会为空,之前都是好好的,只是关闭了服务器,然后又启动了服务器,就这样了!!!
查找了好多资料,都没有相关的解决办法,这个办法是我偶然发现的。也希望这篇文章可以帮助到遇到同样问题的人!!!

想要远程连接你的Ubuntu服务器的图形界面么?这里有个简单的指导告诉你如何使用X2Go来实现,这是一个NX远程桌面协议的衍生版本。
你所需要做的就是在服务器上面安装X2Go服务端和桌面环境,在客户机上安装X2Go的客户端。
在Ubuntu服务器上面的 *** 作:
可以在Ubuntu 1404 LTS, Ubuntu 1204 LTS 和 Ubuntu 1004 LTS 通过PPA找到最新的X2Go服务端版本。先连接上你的Ubuntu服务器,使用下面的命令来安装PPA和相关的包。
在添加PPA之前,需要先安装这个 add-apt-repository:
sudo apt-get install python-software-properties software-properties-common
添加PPA :
sudo apt-add-repository -y ppa:x2go/stable
刷新包列表:
sudo apt-get update
安装X2Go服务器端
sudo apt-get install x2goserver x2goserver-xsession
在这个例子里面我会使用XFCE4作为Ubuntu服务器的桌面环境,安装Xfce4 :
sudo apt-get install xfce4
最后执行 reboot 命令来重启服务器 。
如果你的Ubuntu服务器没有设置主机名,在连接的时候会报错。因此执行下面的命令来设置主机名,把plato替换成你需要的名字:
echo "plato" > /etc/hostname
hostname -F /etc/hostname
在客户端上面的 *** 作:
Windows或者Mac OS X , 请参考这个 安装向导
在Ubuntu 1204, Ubuntu 1004, Ubuntu 1404, 和 Ubuntu 1410 这几个版本中,可以执行下面的命令通过PPA来安装最新的客户端。(或者你可以在Ubuntu 包管理中心安装一个旧版本的客户端):
sudo apt-add-repository ppa:x2go/stable
sudo apt-get update
sudo apt-get install x2goclient
第一次使用客户端的时候,会提醒你设置下面的信息:
连接使用的会话名字
连接使用的图标
远程服务器的IP
登录用户名
ssh端口(默认22)
连接的类型(这个例子里面是XFCE)
如何远程连接Ubuntu 1404 Server 的图形界面
设置完成后,在客户端的窗口右边上,可以看到刚才配置的连接。如果你有更多的远程服务器要连接,可以在session -> new session创建新的连接 。
如何远程连接Ubuntu 1404 Server 的图形界面
从右面板上点击连接会话,输入远程用户密码就可以连接了。
如何远程连接Ubuntu 1404 Server 的图形界面
连接成功后,你就可以在新窗口里面 *** 作你的远程服务器了。

最近对公司的通道机账号进行改造管理,全面的更加深入的理解了公司账号管理的架构。(注:基本上所有的机器上的ssh不能使用,只有部分机器能够使用。为了安全的角度考虑,安装的不是公版的ssh,而都是定制版的ssh,(限制了机器上的源IP地址即可))。

自动化管理服务器,有两种方法:

第一种方法,是我们公司自己开发的(服务器大概是3W台),基本上服务器之间不能够通过ssh互相连通,只能是一台服务器能够连到所有的服务器上,这台服务器我们称之为通道机(也叫堡垒机),当我们想登某台服务器的时候,需要先登上这台通道机,然后经过一系列的验证之后,就能自动的登上你要登到的服务器上。

并且我们自己开发了一套叫做通道机API的方式,来管理3W台服务器,比如收集各台服务器的信息等。其这个API的本质就是使用的是POST的方式将命令post到目标机上,然后返回结果进行处理即可。这是一个大概的思想。

第二种方法,就是使用ssh的协议进行管理,使用python的paramiko来进行管理,下面会进行介绍:

有一些想法,可以使用python的paramiko模块来进行管理名下服务器,前提是能够ssh到各个服务器上。

下面对这个paramiko的模块做个简单的介绍和分享:

1简介:

paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。

由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果

需要使用SSH从一个平台连接到另外一个平台,进行一系列的 *** 作时,paramiko是最佳工具之一。

举个常见的例子,现有这样的需求:需要使用windows客户端,远程连接到Linux服务器,查看上面的日志状态,大家通常使用的方法会是:

1:用telnet

2:用PUTTY

3:用WinSCP

4:用XManager等…

那现在如果需求又增加一条,要从服务器上下载文件,该怎么办?那常用的办法可能会是:

1:Linux上安装FTP并配置

2:Linux上安装Sambe并配置…

大家会发现,常见的解决方法都会需要对远程服务器必要的配置,如果远程服务器只有一两台还好说,如果有N台,还需要逐台进行配置,或者需要使用代码进行以上 *** 作

时,上面的办法就不太方便了。

使用paramiko可以很好的解决以上问题,比起前面的方法,它仅需要在本地上安装相应的软件(python以及PyCrypto),对远程服务器没有配置要求,对于连接多台服

务器,进行复杂的连接 *** 作特别有帮助。

2使用的几个简单的案例:

下面是两种使用paramiko连接到linux服务器的代码:

方式一:

1 ssh = paramikoSSHClient()2 sshset_missing_host_key_policy(paramikoAutoAddPolicy())3 sshconnect("IP地址",22,"用户名","密码")

上面的第二行代码的作用是允许连接不在know_hosts文件中的主机。

方式二:

1 t = paramikoTransport(("IP地址","端口"))2 tconnect(username = “用户名”, password = “口令”)3 如果连接远程主机需要提供密钥,上面第二行代码可改成:4 tconnect(username = “用户名”, password = “口令”, hostkey=”密钥”)

3一些简单的例子:

如果linux服务器开放了22端口,在windows端,我们可以使用paramiko远程连接到该服务器,并执行任意命令,然后通过 print或其它方式得到该结果。

1 #!/usr/bin/python 2 import paramiko3  4 ssh = paramikoSSHClient()5 sshset_missing_host_key_policy(paramikoAutoAddPolicy())6 sshconnect("某IP地址",22,"用户名", "口令")7 stdin, stdout, stderr = sshexec_command("你的命令")8 print stdoutreadlines()9 sshclose()

其中的”你的命令”可以任意linux支持的命令,如一些常用的命令:

1 df:查看磁盘使用情况2 uptime:显示系统运行时间信息3 cat:显示某文件内容4 mv/cp/mkdir/rmdir:对文件或目录进行 *** 作5 /sbin/service/ xxxservice start/stop/restart:启动、停止、重启某服务6 netstat -ntl |grep 8080:查看8080端口的使用情况
7  或者 nc -zv localhost :查看所有端口的使用情况
8 find / -name XXX:查找某文件9

这样一来,对于linux的任何 *** 作几乎都可以通过windows端完成,如果对该功能进行引申,还可以同时管理多台服务器。

4 从widnows端下载linux服务器上的文件

1 #!/usr/bin/python  2 import paramiko 3   4 t = paramikoTransport((“主机”,”端口”)) 5 tconnect(username = “用户名”, password = “口令”) 6 sftp = paramikoSFTPClientfrom_transport(t) 7 remotepath=’/var/log/systemlog’ 8 localpath=’/tmp/systemlog’ 9 sftpget(remotepath, localpath)10 tclose()

5从widnows端上传文件到linux服务器

1 #!/usr/bin/python  2 import paramiko 3  4 t = paramikoTransport((“主机”,”端口”)) 5 tconnect(username = “用户名”, password = “口令”) 6 sftp = paramikoSFTPClientfrom_transport(t) 7 remotepath=’/var/log/systemlog’ 8 localpath=’/tmp/systemlog’ 9 sftpput(localpath,remotepath)10 tclose()


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/13501802.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-08-20
下一篇 2023-08-20

发表评论

登录后才能评论

评论列表(0条)

保存