In this example we're going to setup an HPC environment with AWS ParallelCluster and connect it to Microsoft AD, an AWS service that allows you to create managed Active Directory user pools. You can read more about it in the AD Tutorial.
You have three different options for AD provider, we're going to go with Microsoft AD due to the regional availibility. This allows us to use it in the same region (Ohio) as our hpc6a.48xlarge instances.
| Type | Description | 
|---|---|
| Simple AD | Open AD protocol, supported in only a few regions. | 
| Microsoft AD | Microsoft version, supported in more regions. | 
| AD Connector | Used to bridge on-prem AD. | 
The AD Integration feature was released with AWS ParallelCluster 3.1.1
- Setup Active Directory by launching the stack: CFN Stack in the same region as your cluster.
When it completes you'll see the following the in the stack's Output tab:
- Install AWS ParallelCluster:
Pcluster Manager (Reccomended) https://github.com/aws-samples/pcluster-manager
CLI
pip install aws-parallelcluster- Setup a cluster configuration, for the DirectoryService section, reference the Outputs from the CloudFormation stack you created above to fill in the following:
Note: The IP addresses for the AD domain need to be in the format ldaps://172.31.32.51,ldaps://172.31.67.56
Pcluster Manager
OR
Pcluster Config
DirectoryService:
  DomainName: dc=corp,dc=pcluster,dc=com
  DomainAddr: ldaps://172.31.32.51,ldaps://172.31.67.56
  PasswordSecretArn: arn:aws:secretsmanager:us-east-1:822857487308:secret:ADSecretPassword-pcluster-ad-SmxXwL
  DomainReadOnlyUser: cn=ReadOnlyUser,ou=Users,ou=CORP,dc=corp,dc=pcluster,dc=comTo create a user we'll need to join an instance joined to the admin domain. This can't be done on the cluster. Luckily the stack we created in Part 1 created a t2.micro instance and stopped it.
- 
Click the EC2 Link to see it. The instance is tagged with aws:cloudformation:logical-id=AdDomainAdminNodeif you don't see it.
- 
Next click on the instance checkbox > Actions > Start instance: 
- Once the instance starts RUNNING you can connect to it via Connect button on the upper right.
- Select Session Manager and click Connect.
- Now, once you're on the instance, you'll create the user. First set the admin password from part 1:
ADMIN_PW=[admin password from part 1]- Now create the user, note --display-name=sets the username and username needs to be at the end also.
echo $ADMIN_PW | adcli create-user -x -U Admin --domain=corp.pcluster.com --display-name=username username- 
Now to set the user's password, run the following command locally where username and password are the values you want to set (Note: Admin box doesn't have permissions to do this): DIRECTORY_ID="d-abcdef01234567890" export AWS_DEFAULT_REGION=us-east-1 aws ds reset-user-password \ --directory-id $DIRECTORY_ID \ --user-name "username" \ --new-password "ro-p@ssw0rd" \ --region 'us-east-1' You can find the directory by going to the Cloudformation stack created in Part 1 > Resources > Directory and copy the Physical ID. 




