Sometime there’s the need to do PowerShell remoting from Linux to a Windows System. In my lab environment, I was able to install, configure, and established a PowerShell Remote connection from a Linux Ubuntu 18.04 system to *Active Directory joined Windows System.
*Note: Before trying to following steps, if you’re in a corporate domain, consult with your security team. I would recommend that you try this scenario in virtual machine environment.
I’ve been struggling trying to OpenSSH in both Windows 10 (Build 1803) and Windows Server 2019 with no success connecting from Linux. So, I decided to try install Kerberos component on my Ubuntu system and it works! And, with no need to joined my Linux system to my virtual Active Directory domain.
Install and configuring Kerberos Client
- I need to install and configure the Kerberos Client application on my system:
$ sudo apt-get install krb5-user
- Customizing *krb5.conf file settings for my domain:
$ sudo vim /etc/krb5.conf
- The following are my custom settings in the krb5.conf file for “DOMAINNAME” Kerberos:
[libdefaults] default_realm = DOMAINNAME.COM # The following are custom settings for "DOMAINNAME" Kerberos: dns_lookup_realm = true dns_lookup_kdc = true default_tgs_enctypes = arcfour-hmac-md5 des-cbc-crc des-cbc-md5 default_tkt_enctypes = arcfour-hmac-md5 des-cbc-crc des-cbc-md5 permitted_enctypes = arcfour-hmac-md5 des-cbc-crc des-cbc-md5 [realms] TRINITY.COM = { kdc = DOMAINMACHINENAME admin_server = DOMAINMACHINENAME } [domain_realm] .com = DOMAINNAME
*Note: Make a copy of the krb5.conf file before any changes.
One thing to point out! Both DOMAINNAME and DOMAINMACHINENAME, must be in uppercase.
Configuring ssh
Next step involves in configuring the ssh for Kerberos negotiation. This is the ssh_config file (not sshd_config).
$ sudo vim /etc/ssh/ssh_config
Make sure the following parameters are set at the end of the *ssh_config file:
SendEnv LANG LC_* HashKnownHosts yes GSSAPIAuthentication yes GSSAPIDelegateCredentials no GSSAPIKeyExchange yes
*Note: If there are missing ones, don’t touch the commented ones. Just copy/paste and set the values.
After completing the changes, I would recommend a reboot.
Testing and working Kerberos Client
Here are a few linux commands to work with Kerberos client. If the krb5.conf setting are set correctly, then the following commands should work without any issues.
1. This command will verify user domain, asking for password.
$ kinit username@domainname
2. Shows the list of Kerberos Cached tickets and credential.
$ klist
3. To delete\clear all Kerberos Cache entries:
$ kdestroy
What about setting in Windows Systems?
I’m will cover the whole PowerShell remoting setup. But, I will highlight what’s needed to make Linux connect to a Active Directory Domain system.
- Enable PSRemoting
In PowerShell Conscole, run the “Enable-PSRemoting -force” command line on both client and server. This command will add the firewall rule to allow PowerShell remoting to work.
- Check WinRM Service
Check the Windows Remote Management service is running. By default, in Windows 10 client, this is set to “Manual”.
On the server, just verify that the service running.
Before, connecting Linux to a windows domain system, make sure to test PowerShell remoting between Windows machines. This will guarantee that you got everything working correctly.
Name Resolution Tip
I don’t join my Linux system to my AD domain. So, to resolve my name resolution issues, I manually update the hosts file on my systems. This will include the domain ip-address as well as all other systems
hosts file : xxx.xxx.xxx.xxx domainname.com :
Testing connectivity
Ubuntu 18.04 Connecting to a domain system final test.
1. In Linux, open PowerShell:
$ pwsh
2. Prepare the domain user:
PS /home/user> kinit domainuser
3. Create a *PowerShell Remote interactive session:
PS /home/user> Enter-PSSession -ComputerName wincomputer -Authentication Negotiate -Credential user@domainname.com
*Note: This remote connection will open Windows PowerShell and not PowerShell Core.
Summary
So, in Ubuntu 18.04 installing and configuring Kerberos user client only, you can connect your Linus system to a Active Directory Domain systems. But remember, this will connect to a Windows PowerShell session only.
I’m hoping that in the near future we can have the ability to select a PowerShell versions. Wait!! There’s a way to open a PowerShell Core session instead of Windows PowerShell!!
How To Connect to PowerShell Core
So, by default you’re going to connect to Windows PowerShell. But, if you use the following parameter ‘-ConfigurationName’ folllowed by either ‘PowerShell.6‘ or ‘PowerShell.6-Preview‘ then you’ll get PowerShell Core session. Also, you can use an specific version ‘PowerShell.6.1.0‘.
Enter-PSSession -ComputerName venus -Authentication Negotiate -Credential max_t@trinity.com -ConfigurationName PowerShell.6
Thanks to Steve Lee (Microsoft PowerShell Team) for letting me know this is already available.
References
The following links help figured out the needed components to make my lab environment work.