zoukankan      html  css  js  c++  java
  • 部署CDH集群环境准备

    一、系统centOS7以上,至少三台主机

      添加ip 主机名映射关系:(每台主机都要做)

      vim /etc/hosts  

        127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
        ::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
        10.0.8.107 master
        10.0.8.108 node1
        10.0.8.114 node2

    二、配置免密登陆

      Hadoop运行过程中需要管理远端Hadoop守护进程,在Hadoop启动以后,NameNode是通过SSH(Secure Shell)来启动和停止各个DataNode上的各种守护进程的。这就必须在节点之间执行指令的时候是不需要输入密码的形式,所以我们需要配置SSH运用无密码公钥认证的形式,这样NameNode使用SSH无密码登录并启动DataName进程,同样原理,DataNode上也能使用SSH无密码登录到NameNode。 

      生成公钥私钥:
      ssh-keygen -t rsa   #三次确认

      

      将公钥copy到需要免密登陆的服务器上  

        ssh-copy-id master
        ssh-copy-id node1
        ssh-copy-id node2

    三、ntp时钟同步

        CDH集群高度依赖时钟同步,所以需要所有节点的服务器时间都一样,这时候可以自己搭一套ntp同步server;也可以用公共的时钟同步服务器;

        ntpdate ntp1.aliyun.com   #阿里云时钟同步服务器

        创建时钟同步计划任务:

          crontab -e  #创建计划任务

          */5 * * * * /usr/sbin/ntpdate ntp1.aliyun.com > /dev/null 2>&1   #表示每5min同步一次时间     

          [root@master ~]# crontab -l  #查看计划任务  (每台设备都要做)
          */5 * * * * /usr/sbin/ntpdate ntp.sinocache.net > /dev/null 2>&1   

    四、系统调优

      1、关闭防火墙和selinux;

      2、关闭dns反向查寻,优化登陆时间,如果不关登陆会很慢,会有一个dns反向查寻的时间;

        sed -i 's@#UseDNS yes@UseDNS no@g' /etc/ssh/sshd_config

      3、关闭GSSAPI身份验证

        sed -i 's@^GSSAPIAuthentication yes@GSSAPIAuthentication no@g' /etc/ssh/sshd_config

      GSSAPIAuthentication  当这个参数开启( GSSAPIAuthentication  yes )的时候,通过SSH登陆服务器时候会有些会很慢!这是由于服务器端启用了GSSAPI。登陆的时候客户端需要对服务器端的IP地                址进行反解析,如果服务器的IP地址没有配置PTR记录,那么就容易在这里卡住了。

      4、关闭透明大页

        (vir-3.5.2) [root@master ~]# uname -r   #查看内核版本
        3.10.0-862.el7.x86_64
        (vir-3.5.2) [root@master ~]# cat /sys/kernel/mm/transparent_hugepage/enabled
        [always] madvise never   #查看透明大页状态,打开状态
        (vir-3.5.2) [root@master ~]# cat /etc/default/grub | grep GRUB_CMDLINE_LINUX
        GRUB_CMDLINE_LINUX="crashkernel=auto console=ttyS0 console=tty0 panic=5 net.ifnames=0 biosdevname=0"
        (vir-3.5.2) [root@master ~]# vim /etc/default/grub

        GRUB_TIMEOUT=5
        GRUB_DISTRIBUTOR="$(sed 's, release .*$,,g' /etc/system-release)"
        GRUB_DEFAULT=saved
        GRUB_DISABLE_SUBMENU=true
        GRUB_TERMINAL="serial console"
        GRUB_TERMINAL_OUTPUT="serial console"
        GRUB_CMDLINE_LINUX="crashkernel=auto console=ttyS0 console=tty0 panic=5 net.ifnames=0 biosdevname=0 transparent_hugepage=never"    #加上标红的配置
        GRUB_DISABLE_RECOVERY="true"
        GRUB_SERIAL_COMMAND="serial --speed=9600 --unit=0 --word=8 --parity=no --stop=1"

        (vir-3.5.2) [root@master ~]# grub2-mkconfig -o /boot/grub2/grub.cfg  #加载配置文件

        Generating grub configuration file ...
        Found linux image: /boot/vmlinuz-3.10.0-862.el7.x86_64
        Found initrd image: /boot/initramfs-3.10.0-862.el7.x86_64.img
        Found linux image: /boot/vmlinuz-0-rescue-c28d40cbc8e3adcb4e32d9779a77b39e
        Found initrd image: /boot/initramfs-0-rescue-c28d40cbc8e3adcb4e32d9779a77b39e.img
        done

        (vir-3.5.2) [root@master ~]# reboot  #重启配置才能生效;

        (vir-3.5.2) [root@master ~]# cat /sys/kernel/mm/transparent_hugepage/enabled

        always madvise [never]  #重启后查看状态为关闭状态

      5、关闭碎片整理

        THP压缩会降低Hadoop的性能。所以,禁用碎片整理是一个很好的做法。

        (vir-3.5.2) [root@master ~]# vim /etc/rc.d/rc.local

        #!/bin/bash

        touch /var/lock/subsys/local
        /usr/local/qcloud/irq/net_smp_affinity.sh >/tmp/net_affinity.log 2>&1
        /usr/local/qcloud/rps/set_rps.sh >/tmp/setRps.log 2>&1
        /usr/local/qcloud/gpu/nv_gpu_conf.sh >/tmp/nv_gpu_conf.log 2>&1

        #在该文件加上该配置即可
        if test -f /sys/kernel/mm/transparent_hugepage/enabled; then
        echo never > /sys/kernel/mm/transparent_hugepage/enabled
        fi

        if test -f /sys/kernel/mm/transparent_hugepage/defrag; then
        echo never > /sys/kernel/mm/transparent_hugepage/defrag
        fi

        (vir-3.5.2) [root@master ~]# ll /etc/rc.d/rc.local   #查看该文件是否有执行权限,如果没有需要加执行权限;

        chmod +x /etc/rc.d/rc.local
        -rwxr-xr-x 1 root root 943 Jun 30 00:59 /etc/rc.d/rc.local

      6、修改Linux内核参数

        (vir-3.5.2) [root@master ~]# vim /etc/sysctl.conf   ##编辑该文件,并加入一下配置;

        fs.aio-max-nr=1048576

        net.core.rmem_default=262144

        net.core.wmem_default=262144
        net.core.rmem_max=16777216
        net.core.wmem_max=16777216
        net.ipv4.tcp_rmem=4096 262144 16777216
        net.ipv4.tcp_wmem=4096 262144 16777216

        (vir-3.5.2) [root@master ~]# sysctl -p   #加载配置文件使其生效

    fs.aio-max-nr = 1048576       ##最大并发I/O请求数
    net.core.rmem_default = 262144   ##操作系统接收缓冲区的默认大小
    net.core.wmem_default = 262144  ##操作系统发送缓冲区的默认大小
    net.core.rmem_max = 16777216   ##操作系统接收缓冲区最大值
    net.core.wmem_max = 16777216  ##操作系统发送缓冲区最大值
    net.ipv4.tcp_rmem = 4096 262144 16777216  ##接收窗口尺寸的最小,默认,最大值
    net.ipv4.tcp_wmem = 4096 262144 16777216  ##发送窗口尺寸的最小,默认,最大值

    7、增加文件限制

      (vir-3.5.2) [root@master ~]# ulimit -Sn   #软限制(由于我这是云主机,应该是腾讯云已经做了优化的,标准原生镜像应该是1024)

        100001
        (vir-3.5.2) [root@master ~]# ulimit -Hn   #硬限制 (原生镜像应该是4096)
        100002

        如果其他人不是我这样的配置就得手动自己改了,方法如下:

        vim /etc/security/limits.conf

        (vir-3.5.2) [root@master ~]# tail -8 /etc/security/limits.conf

        * soft nofile 1048576  ##表示用户和组,如果是"*",则表示所有用户或组进行限制。
        * hard nofile 1048576  ##表示软限制还是硬限制,当进程使用的资源超过软限制时系统日志会有警告产生,当进程使用的资源达到硬限制时,则无法继续使用更多的限制,甚至有的程序会直接抛出异常,比如MySQL程序。
        * soft nproc 1048576  ##表示限制的资源类型
        * hard nproc 1048576 ##如nofile表示打开文件描述符的最大数目,memlock表示最大锁定内存地址空间(KB),nporc表示最大数量的进程,as表示地址空间的限制(KB),cpu表示最大CPU时间(分钟)等等。
        * soft memlock unlimited  ##表示限制的最大值,也就是我们针对某个参数配置的具体数值。比如"* soft nofile 1048576",表示任何用户对于文件句柄数的软限制最大打开文件描述符是1048576。
        * hard memlock unlimited

        (vir-3.5.2) [root@master ~]# tail -2 /etc/security/limits.d/20-nproc.conf

        * soft nproc 1048576
        root soft nproc unlimited 

        ##"/etc/security/limits.conf" 配置文件可限制文件打开数,系统进程等资源,在该文件配置中写的最大用户进程数是受"/etc/security/limits.d/90-nproc.conf"配置上限影响的。

      一般系统普通用户进程数满了都是修改/etc/security/limits.d/90-nproc.conf文件。

      8、禁用swap

        swapon -s  #查看swap状态

        swapoff -a  #关闭swap
        swapon -s  #打开swap
        free -h        #确认swap是否为0

  • 相关阅读:
    Kali Linux渗透基础知识整理(二)漏洞扫描
    Elasticsearch为记录添加时间戳timestamp
    手把手带你使用JS-SDK自定义微信分享效果
    SpringBoot学习(3)-SpringBoot添加支持CORS跨域访问
    Java 骚操作--生成二维码
    清除微信内置浏览器缓存
    使用python脚本Telnet 华为交换机备份配置
    如何备份思科、锐捷、Juniper的配置文件
    微信公众平台开发教程Java版(六) 事件处理(菜单点击/关注/取消关注)
    How do you build a database?
  • 原文地址:https://www.cnblogs.com/zhangzhide/p/11108472.html
Copyright © 2011-2022 走看看