本节讲解在安装软件及搭建集群之前配置CentOS 7系统环境的一些操作。
本书中使用1.3节安装操作系统时新建的hadoop用户进行后续的操作,读者若想使用其他用户,可按照下面的步骤新建用户。例如,新建用户tom:
01 使用“su -”命令切换为root用户,然后执行以下命令:
$ adduser tom
02 执行以下命令,设置用户tom的密码:
$ passwd tom
到此,用户tom新建成功。
为了使普通用户可以使用root权限执行相关命令(例如,系统文件的修改等),而不需要切换到root用户,可以在命令前面加入指令sudo。文件/etc/sudoers中设置了可执行sudo指令的用户,因此需要修改该文件,添加相关用户。
例如,使hadoop用户可以执行sudo指令,操作步骤如下:
01 使用“su -”命令切换为root用户,然后执行以下命令,修改文件sudoers:
$ vi /etc/sudoers
02 在文本root ALL=(ALL) ALL的下方加入以下代码,使hadoop用户可以使用sudo命令:
hadoop ALL=(ALL) ALL
03 执行sudo命令对系统文件进行修改时需要验证当前用户的密码,默认5分钟后密码过期,下次使用sudo需要重新输入密码。如果不想输入密码,则把上方的代码换成以下内容即可:
hadoop ALL=(ALL) NOPASSWD:ALL
04 执行exit命令回到hadoop用户,此时要使用root权限只需要在命令前面加入sudo即可,无须输入密码。例如,以下命令:
$ sudo cat /etc/sudoers
安装操作系统时创建的管理员用户hadoop,默认可以执行sudo命令,但需要验证Hadoop用户的密码。可对其按照上面的步骤操作无须密码使用sudo命令。
集群通常都是内网搭建的,如果内网开启防火墙,内网集群通信则会受到防火墙的干扰,因此需要关闭集群中所有节点的防火墙,操作步骤如下:
01 执行以下命令关闭防火墙:
$ sudo systemctl stop firewalld.service
02 然后执行以下命令,禁止防火墙开机启动:
$ sudo systemctl disable firewalld.service
03 若需要查看防火墙是否已经关闭,可以执行以下命令,查看防火墙的状态:
$ sudo firewall-cmd --state
04 此外,开启防火墙的命令如下:
$ sudo systemctl start firewalld.service
为避免后续启动操作系统后,因IP地址改变,而导致集群间通信失败,节点间无法正常访问,需要将操作系统的IP状态设置为固定IP,具体操作步骤如下:
单击VMware菜单栏中的【编辑】|【虚拟网络编辑器】命令,在弹出的【虚拟网络编辑器】窗口的上方表格中选择最后一行,即外部连接为【NAT模式】,然后单击下方的【NAT设置】按钮,如图2-1所示。
在弹出的【NAT设置】窗口中,查看VMware分配的【网关IP】。可以看到,本例中的网关IP为192.168.170.2(网段为170,也可手动修改为其他网段,此处保持默认),如图2-2所示。
图2-1 选择外部NAT模式
图2-2 查看VMware网关IP
需要注意的是,后续为VMware中的操作系统设置IP时,网关IP应与图2-2中的网关IP保持一致。
CentOS 7系统IP的配置方法有两种:桌面配置方式和命令行配置方式,下面分别进行讲解。
(1)桌面配置方式
单击系统桌面右上角的倒三角按钮,在弹出的窗口中单击【有线设置】选项,如图2-3所示。
在弹出的窗口中单击下方的【添加配置】按钮,如图2-4所示。
图2-3 系统有线网络设置
图2-4 添加网络配置
在弹出的【网络配置】窗口中,左侧单击选择【IPv4】,右侧的【地址】选择【手动】。
接着输入IP地址、网络掩码、网关和DNS服务器信息。IP地址可以自定义,范围在1~254,IP地址的网段应与网关一致,此处将IP地址设置为192.168.170.133。输入完毕后单击【添加】按钮,如图2-5所示。
图2-5 填写网络配置信息
(2)命令行配置方式
在系统终端命令行窗口执行以下命令,修改文件ifcfg-ens33:
$ sudo vim /etc/sysconfig/network-scripts/ifcfg-ens33
完整修改后的内容如下:
上述内容中,实线框标注的是修改的内容,虚线框标注的是添加的内容。
需要修改的属性及解析如下:
·BOOTPROTO:值static表示静态IP(固定IP),默认值是dhcp,表示动态IP。
·ONBOOT:yes表示开机启用本配置。
需要添加的属性及解析如下:
·IPADDR:IP地址。
·NETMASK:子网掩码。
·GATEWAY:默认网关。虚拟机安装的话,通常是2,即VMnet8的网关设置。
·DNS1:DNS配置。虚拟机安装的话,与网关一致。若需要连接外网,需要配置DNS。
·DNS2:网络运营商公众DNS,此处也可省略。
修改完成后执行以下命令,重启网络服务,使修改生效:
$ sudo service network restart
重启完成后,可以通过ifconfig命令或者以下命令,查看改动后的IP:
$ ip addr
在输出的信息中,若网卡ens33对应的IP地址已显示为设置的地址,说明IP修改成功,如图2-6所示。
图2-6 查看系统IP地址
在本地Windows系统中打开cmd命令行窗口,使用ping命令访问虚拟机中操作系统的IP地址,命令如下:
$ ping 192.168.170.133
若能成功返回数据,说明从本地Windows可以成功访问虚拟机中的操作系统,便于后续从本地系统进行远程操作。
在分布式集群中,主机名用于区分不同的节点,方便节点之间相互访问,因此需要修改主机的主机名。具体操作步骤如下:
01 使用hadoop用户登录系统,进入系统的终端命令行,输入以下命令,查看主机名:
$ hostname localhost.localdomain
从输出的信息中可以看到,当前主机的默认主机名为localhost.localdomain。
02 执行以下命令,设置主机名为centos01:
$ sudo hostname centos01
此时系统的主机名已修改为centos01,但是重启系统后此修改将失效,要想永久改变主机名,需要修改/etc/hostname文件。
执行以下命令,修改hostname文件,将其中的默认主机名改为centos01:
$ sudo vi /etc/hostname
03 执行reboot命令,重启系统使修改生效。
需要注意的是,修改主机名后需要重启操作系统才能生效。
在目录/opt下创建softwares和modules两个文件夹,分别用于存放软件安装包和软件安装后的程序文件,命令如下:
$ sudo mkdir /opt/softwares $ sudo mkdir /opt/modules
将目录/opt及其子目录中所有文件的所有者和组更改为用户hadoop和组hadoop,命令如下:
$ sudo chown -R hadoop:hadoop /opt/*
查看目录权限是否修改成功,命令及输出信息如下:
$ ll 总用量 0 drwxr-xr-x. 2 hadoop hadoop 6 3月 8 09:55 modules drwxr-xr-x. 2 hadoop hadoop 6 3月 26 2015 rh drwxr-xr-x. 2 hadoop hadoop 231 3月 8 09:07 softwares