本指南将向你介绍如何使用 Authconfig 在命令行中将无图形界面的 CentOS 7 服务器集成到 Samba4 AD 域控制器中。

这类设置提供了由 Samba 持有的单一集中式帐户数据库,允许 AD 用户通过网络基础设施对 CentOS 服务器进行身份验证。

要求

  1. 在 Ubuntu 上使用 Samba4 创建 AD 基础架构
  2. CentOS 7.3 安装指南

步骤 1:为 Samba4 AD DC 配置 CentOS

1、 在开始将 CentOS 7 服务器加入 Samba4 DC 之前,你需要确保网络接口被正确配置为通过 DNS 服务查询域。

运行 ip address 命令列出你机器网络接口,选择要编辑的特定网卡,通过针对接口名称运行 nmtui-edit 命令(如本例中的 ens33),如下所示。

  1. # ip address
  2. # nmtui-edit ens33

列出网络接口

2、 打开网络接口进行编辑后,添加最适合 LAN 的静态 IPv4 配置,并确保为 DNS 服务器设置 Samba AD 域控制器 IP 地址。

另外,在搜索域中追加你的域的名称,并使用 [TAB] 键跳到确定按钮来应用更改。

当你仅对域 dns 记录使用短名称时, 已提交的搜索域保证域对应项会自动追加到 dns 解析 (FQDN) 中。

配置网络接口

3、最后,重启网络守护进程以应用更改,并通过对域名和域控制器 ping 来测试 DNS 解析是否正确配置,如下所示。

  1. # systemctl restart network.service
  2. # ping -c2 tecmint.lan# ping -c2 adc1
  3. # ping -c2 adc2

验证域上的 DNS 解析

4、 另外,使用下面的命令配置你的计算机主机名并重启机器应用更改。

  1. # hostnamectl set-hostname your_hostname
  2. # init 6

使用以下命令验证主机名是否正确配置。

  1. # cat /etc/hostname
  2. # hostname

5、 最后,使用 root 权限运行以下命令,与 Samba4 AD DC 同步本地时间。

  1. # yum install ntpdate
  2. # ntpdate domain.tld

与 Samba4 AD DC 同步时间

步骤 2:将 CentOS 7 服务器加入到 Samba4 AD DC

6、 要将 CentOS 7 服务器加入到 Samba4 AD 中,请先用具有 root 权限的帐户在计算机上安装以下软件包。

  1. # yum install authconfig samba-winbind samba-client samba-winbind-clients

7、 为了将 CentOS 7 服务器与域控制器集成,可以使用 root 权限运行 authconfig-tui,并使用下面的配置。

  1. # authconfig-tui

首屏选择:

  • 在 User Information 中:

    • Use Winbind
  • 在 Authentication 中使用[空格键]选择:
    • Use Shadow Password
    • Use Winbind Authentication
    • Local authorization is sufficient

验证配置

8、 点击 Next 进入 Winbind 设置界面并配置如下:

  • Security Model: ads
  • Domain = YOUR_DOMAIN (use upper case)
  • Domain Controllers = domain machines FQDN (comma separated if more than one)
  • ADS Realm = YOUR_DOMAIN.TLD
  • Template Shell = /bin/bash

Winbind 设置

9、 要加入域,使用 [tab] 键跳到 “Join Domain” 按钮,然后按[回车]键加入域。

在下一个页面,添加具有提升权限的 Samba4 AD 帐户的凭据,以将计算机帐户加入 AD,然后单击 “OK” 应用设置并关闭提示。

请注意,当你输入用户密码时,凭据将不会显示在屏幕中。在下面再次点击 OK,完成 CentOS 7 的域集成。

加入域到 Samba4 AD DC

确认 Winbind 设置

要强制将机器添加到特定的 Samba AD OU 中,请使用 hostname 命令获取计算机的完整名称,并使用机器名称在该 OU 中创建一个新的计算机对象。

将新对象添加到 Samba4 AD 中的最佳方法是已经集成到安装了 RSAT 工具的域的 Windows 机器上使用 ADUC 工具。

重要:加入域的另一种方法是使用 authconfig 命令行,它可以对集成过程进行广泛的控制。

但是,这种方法很容易因为其众多参数造成错误,如下所示。该命令必须输入一条长命令行。

  1. # authconfig --enablewinbind --enablewinbindauth --smbsecurity ads --smbworkgroup=YOUR_DOMAIN --smbrealm YOUR_DOMAIN.TLD --smbservers=adc1.yourdomain.tld --krb5realm=YOUR_DOMAIN.TLD --enablewinbindoffline --enablewinbindkrb5 --winbindtemplateshell=/bin/bash--winbindjoin=domain_admin_user --update  --enablelocauthorize   --savebackup=/backups

10、 机器加入域后,通过使用以下命令验证 winbind 服务是否正常运行。

  1. # systemctl status winbind.service

11、 接着检查是否在 Samba4 AD 中成功创建了 CentOS 机器对象。从安装了 RSAT 工具的 Windows 机器使用 AD 用户和计算机工具,并进入到你的域计算机容器。一个名为 CentOS 7 Server 的新 AD 计算机帐户对象应该在右边的列表中。

12、 最后,使用文本编辑器打开 samba 主配置文件(/etc/samba/smb.conf)来调整配置,并在 [global] 配置块的末尾附加以下行,如下所示:

  1. winbind use default domain = true
  2. winbind offline logon = true

配置 Samba

13、 为了在 AD 帐户首次登录时在机器上创建本地家目录,请运行以下命令:

  1. # authconfig --enablemkhomedir --update

14、 最后,重启 Samba 守护进程使更改生效,并使用一个 AD 账户登陆验证域加入。AD 帐户的家目录应该会自动创建。

  1. # systemctl restart winbind
  2. # su - domain_account

验证域加入

15、 通过以下命令之一列出域用户或域组。

  1. # wbinfo -u
  2. # wbinfo -g

列出域用户和组

16、 要获取有关域用户的信息,请运行以下命令。

  1. # wbinfo -i domain_user

列出域用户信息

17、 要显示域摘要信息,请使用以下命令。

  1. # net ads info

列出域摘要

步骤 3:使用 Samba4 AD DC 帐号登录CentOS

18、 要在 CentOS 中与域用户进行身份验证,请使用以下命令语法之一。

  1. # su - ‘domain\domain_user’
  2. # su - domain\\domain_user

或者在 samba 配置文件中设置了 winbind use default domain = true 参数的情况下,使用下面的语法。

  1. # su - domain_user
  2. # su - domain_user@domain.tld

19、 要为域用户或组添加 root 权限,请使用 visudocommand 编辑 sudoers 文件,并添加以下截图所示的行。

  1. YOUR_DOMAIN\\domain_username             ALL=(ALL:ALL) ALL      #For domain users
  2. %YOUR_DOMAIN\\your_domain\  group            ALL=(ALL:ALL) ALL  #For domain groups

或者在 samba 配置文件中设置了 winbind use default domain = true 参数的情况下,使用下面的语法。

  1. domain_username                  ALL=(ALL:ALL) ALL      #For domain users
  2. %your_domain\  group             ALL=(ALL:ALL) ALL  #For domain groups

授予域用户 root 权限

20、 针对 Samba4 AD DC 的以下一系列命令也可用于故障排除:

  1. # wbinfo -p #Ping domain
  2. # wbinfo -n domain_account #Get the SID of a domain account
  3. # wbinfo -t  #Check trust relationship

21、 要离开该域, 请使用具有提升权限的域帐户对你的域名运行以下命令。从 AD 中删除计算机帐户后, 重启计算机以在集成进程之前还原更改。

  1. # net ads leave -w DOMAIN -U domain_admin
  2. # init 6

就是这样了!尽管此过程主要集中在将 CentOS 7 服务器加入到 Samba4 AD DC 中,但这里描述的相同步骤也适用于将 CentOS 服务器集成到 Microsoft Windows Server 2012 AD 中。

作者:Matei Cezar
来源:51CTO

在命令行中将CentOS 7与Samba4 AD集成相关推荐

  1. c++制表符_在Linux命令行中将制表符(tab)转换为空格

    请关注本头条号,每天坚持更新原创干货技术文章. 如需学习视频,请在微信搜索公众号"智传网优"直接开始自助视频学习 1. 前言 本教程将从编程的角度向您介绍如何在Linux命令行中将 ...

  2. 纯命令行的centos如何通过上网认证的解决方案

    (一)问题描述:所在网络打开网页,会跳到认证页面,需要输入用户名和密码,认证通过后,才会正常上网.对于纯命令行的centos,无法通过浏览器进入认证页面进行认证. (二)解决手段:使用curl命令模拟 ...

  3. 使用命令行登录CentOS系统

    使用命令行登录CentOS系统 localhost login:后面输入root并回车,然后输入ROOT密码,进入CentOS系统. 倒数第2行提示我们上一次root用户登录系统的时间以及终端(tty ...

  4. 命令行版 Centos 7 虚拟机安装 xfce4 桌面 + x11vnc + novnc

    命令行版 Centos 7 虚拟机安装 xfce4 桌面 + x11vnc + novnc 安装命令行版 Centos 7 虚拟机 xfce4 桌面环境 安装 x server 安装.启动 xfce4 ...

  5. linux打开csv命令,在Linux命令行中将xlsx转换为csv

    Gnumeric电子表格应用程序附带一个名为ssconvert的命令行实用程序,可以在各种电子表格格式之间进行转换: $ ssconvert Book1.xlsx newfile.csv Using ...

  6. Samba 系列(九):将 CentOS 7 桌面系统加入到 Samba4 AD 域环境中

    这篇文章讲述了如何使用 Authconfig-gtk 工具将 CentOS 7 桌面系统加入到 Samba4 AD 域环境中,并使用域帐号登录到 CentOS 系统. 要求 1.在 Ubuntu 系统 ...

  7. CentOS 7系统启动后怎么从命令行模式切换到图形界面模式

    一.存在问题 在VMware虚拟机中成功安装centOS 7系统后,如果启动centOS 7系统直接进入命令行模式,没有进入操作系统桌面模式,那么应该是没有配置安装GUI图形界面的程序包所致,启动系统 ...

  8. CentOS 7系统启动后怎样从命令行模式切换到图形界面模式

    感谢平台分享-http://bjbsair.com/2020-04-10/tech-info/53237.html 一.存在问题 在VMware虚拟机中成功安装centOS 7系统后,如果启动cent ...

  9. linux字符串转大写_在 Linux 命令行中转换大小写

    转换文本的大小写可能非常繁琐,尤其是当你要避免无意间的拼写错误时.幸运的是,Linux 提供了一些命令,可以使工作变得非常容易. -- Sandra Henry-stocker(作者) 有很多方法可以 ...

最新文章

  1. java中super用来定义父类,Java中super的几种用法及与this的区别
  2. 如何用Python实现超级玛丽的人物行走和碰撞检测?
  3. 热修复框架Tinker的从0到集成之路(转)
  4. C语言求:1到100之间的所有素数之和
  5. PWN-PRACTICE-BUUCTF-19
  6. M-JPEG、MPEG4、H.264都有何区别 依维安防论坛
  7. linux 无法打开.ttf_win7系统ttf文件打不开怎么办【解决方法】
  8. keepalived高可用lvs集群,主/备和主/主模型
  9. 支付宝一键清除首页各种广告
  10. 基于JAVA+SpringMVC+Mybatis+MYSQL的快递代拿系统
  11. 现在大家都使用支付宝和微信支付,为何银行还准备大量的现金?
  12. CSS3过渡效果(CSS3)
  13. 大腾讯的第一个开源项目「Tinker」
  14. 中国指数基金与ETF价格战简史(1)
  15. java会导致蓝屏么_电脑经常会蓝屏?可能是这些原因导致的
  16. 【cs231n学习笔记(2017)】—— 神经网络激活函数
  17. 谷粒学苑上传视频踩坑
  18. .7z.001 这种让人头疼的分卷格式
  19. abs int 宏定义_【C语言】15-预处理指令1-宏定义
  20. Nature:交互式语言的语音规划网络

热门文章

  1. ERROR: Process pool report error: Can‘t pickle
  2. Glances:一款功能强大的操作系统安全监控平台
  3. python删除、替换字符串某字符后的字符串(删除字符串、替换字符串、strip、split、rstrip、lstrip、replace)
  4. 汇编编译器以及 DOSBox0.74的安装使用(虚拟)64位
  5. git报错:fatal: remote origin already exists
  6. CEF3—在网页加载前给js对象填值
  7. Linux awk命令使用方法
  8. BZOJ 4810 [Ynoi2017]由乃的玉米田(莫队+bitset)
  9. PHP以xml形式获取POST数据
  10. 构造函数失败_抛出异常