KEMBAR78
Devops Java Project | PDF | Sudo | Secure Shell
0% found this document useful (0 votes)
41 views13 pages

Devops Java Project

The document provides a comprehensive guide for setting up Java and Maven in Ubuntu within the Windows Subsystem for Linux (WSL), highlighting the advantages of using WSL for a smoother development experience. It includes step-by-step instructions for installing Java, configuring environment variables, and setting up Maven, along with troubleshooting tips for common issues. Additionally, it covers Git installation and configuration, GitHub authentication, and creating an Azure Virtual Machine for further development needs.

Uploaded by

1mp22ad002
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
41 views13 pages

Devops Java Project

The document provides a comprehensive guide for setting up Java and Maven in Ubuntu within the Windows Subsystem for Linux (WSL), highlighting the advantages of using WSL for a smoother development experience. It includes step-by-step instructions for installing Java, configuring environment variables, and setting up Maven, along with troubleshooting tips for common issues. Additionally, it covers Git installation and configuration, GitHub authentication, and creating an Azure Virtual Machine for further development needs.

Uploaded by

1mp22ad002
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 13

We are setting up Java and Maven in Ubuntu inside WSL because:

1.​ WSL Provides a Linux Environment on Windows


○​ Many DevOps tools (like Ansible, Jenkins, and Azure CLI) run more
smoothly in Linux.
○​ It avoids compatibility issues that sometimes arise in Windows.
2.​ Easier Dependency Management
○​ Package management with apt is more efficient than manually
setting up dependencies in Windows.
○​ Updates and installations are streamlined.
3.​ Consistent Development & Deployment
○​ Most cloud servers and CI/CD pipelines run on Linux.
○​ Developing in WSL ensures that your local environment is closer to
production.
4.​ Better Command Line Experience
○​ Bash scripting and Linux commands are widely used in automation.
○​ Native Linux tools (like ssh, curl, grep) are easier to use.

Step 1: Setting Up Java & Maven in WSL

Introduction

In this step, we will configure Java and Maven inside Windows Subsystem for Linux (WSL).
Java is required to run and build Java applications, while Maven is a powerful build automation
tool that manages dependencies and project builds efficiently.

We will cover:

✅ Updating package lists to ensure we have the latest versions


✅ Installing OpenJDK 17 (or 21) for Java development
●​

✅ Setting up JAVA_HOME and updating the system path


●​

✅ Installing and verifying Apache Maven for project management


●​
●​

This setup will ensure that our development environment is properly configured to run Java
applications and manage builds effectively.

Step-by-Step Navigation
🔹 Step 1: Open WSL Terminal
1.​ Press Win + R, type wsl, and press Enter.​
(Make sure WSL is installed and running.)
2.​ If you are not inside Ubuntu, run:​
wsl -d Ubuntu

🔹 Step 2: Update Package Lists


1.​ In the WSL Ubuntu terminal, run:​
sudo apt update && sudo apt upgrade -y
2.​ This updates the package list and upgrades existing packages.
3.​ If prompted for a password, enter your Ubuntu user password.

🔹 Step 3: Install Java (JDK 17 or 21)


1.​ To install Java 17, run:​
sudo apt install openjdk-17-jdk -y​
(For Java 21, replace 17 with 21.)

Verify installation:​
java -version


2.​ javac -version​
If Java is installed, you’ll see version details.

🔹 Step 4: Set Java Home Path


Run:​
echo 'export JAVA_HOME=/usr/lib/jvm/java-17-openjdk-amd64' >> ~/.bashrc
echo 'export PATH=$JAVA_HOME/bin:$PATH' >> ~/.bashrc

1.​ source ~/.bashrc


2.​ Verify Java Home:​


echo $JAVA_HOME​
This should display /usr/lib/jvm/java-17-openjdk-amd64.
🔹 Step 5: Install Maven
1.​ Install Maven by running:​
sudo apt install maven -y
2.​ Verify installation:​


mvn -version​
If installed correctly, it will display the Maven version.

—----------------------------------------------------------------

If WSL is saying "No such file or directory", it means one of the following:

1.​ The path is incorrect.


2.​ Windows drives are not mounted in WSL.
3.​ You are using the wrong username in the path.

Steps to Fix It:

✅ Step 1: Check If Windows Drives Are Mounted in WSL


Run the following command in WSL:

ls /mnt/c

This should list your C: drive contents. If nothing appears, your Windows drive is not mounted.
Try:

sudo mount -t C: /mnt/c

✅ Step 2: Check the Exact Path in Windows


1.​ Open File Explorer in Windows.
2.​ Navigate to your project folder.
3.​ Copy the full path from the address bar (e.g.,
C:\Users\YourName\Projects\Devips).

✅ Step 3: Convert Windows Path to WSL Path


Convert the path you copied to WSL format:

●​ Replace C:\ with /mnt/c/.


●​ Replace all \ with /.
Example:​
Windows Path:

C:\Users\YourName\Projects\Devips

WSL Path

/mnt/c/Users/YourName/Projects/Devips

Then run:

cd /mnt/c/Users/YourName/Projects/Devips

ls

If the folder exists, you should see your project files.

✅ Step 4: Verify That Your Folder Exists


If you still get an error, check if the folder exists with:

bash

CopyEdit

ls -ld /mnt/c/Users/YourName/Projects/Devips

●​ If it says "No such file or directory", confirm the correct username in the path.

If you see permissions issues, try running:​


bash​
CopyEdit​
sudo chmod -R 777 /mnt/c/Users/YourName/Projects/Devips

●​

Try these steps and let me know what happens! 🚀


—---------------------------------------------------------------
To install Java 17 in WSL, follow these steps:

Step 1: Uninstall Java 21 (if installed)

Run the following command to check the installed Java version:

java -version

If Java 21 is installed, remove it:

bash

CopyEdit

sudo apt remove --purge openjdk-21-jdk -y

sudo apt autoremove -y

Step 2: Install Java 17

Now, install Java 17:

sudo apt update

sudo apt install -y openjdk-17-jdk

Step 3: Verify Java 17 Installation

After installation, confirm the version:

java -version

It should show something like:

openjdk version "17.0.x" ...


Step 4: Set Java 17 as Default (if needed)

If multiple Java versions are installed, set Java 17 as the default:

sudo update-alternatives --config java

Select Java 17 from the list.

Now, your WSL is using Java 17! 🚀


Try running mvn clean install to verify everything
works. Let me know if you need any changes!

Yes, you can run commands inside your project folder in WSL. First, make sure you navigate to
the correct path:

Navigate to Your Project Folder in WSL

bash

CopyEdit

cd /mnt/c/Users/YourName/Projects/Devips

(Replace YourName with your actual Windows username.)

Check Java Version

Ensure Java 17 is installed:

java -version

If it's still showing Java 21, switch to Java 17:

sudo update-alternatives --config java

Select the correct Java 17 option.

Run Maven Build


Now, inside the project folder, run:

mvn clean install

This will compile and package your Maven project.

Let me know if you face any issues! 🚀


—-----------------------------------------------------------------------------------------

Step 2: Install & Configure Git, GitHub Authentication

✅ Step 2.1: Install Git on Windows & WSL


Install Git on Windows:

1.​ Download Git from Git for Windows.


2.​ Install it with default settings.
3.​ Verify installation:​
git --version

Install Git on WSL:

1.​ Open WSL and install Git:​


sudo apt update && sudo apt install -y git
2.​ Verify installation:​
git --version

✅ Step 2.2: Configure Git


Set up your Git identity:​
git config --global user.name "Your Name"
1.​ git config --global user.email "your.email@example.com"
2.​ Verify your Git configuration:​
git config --list

✅ Step 2.3: Authenticate GitHub via SSH


Navigation Steps:

1.​ Generate an SSH key (if not already created):​


ssh-keygen -t rsa -b 4096 -C "your.email@example.com"
○​ Press Enter to save in the default location.
○​ Set a passphrase (optional but recommended).

○​

Start the SSH agent and add your key:​


eval "$(ssh-agent -s)"

2.​ ssh-add ~/.ssh/id_rsa

3.​ Copy the SSH key to GitHub:​


cat ~/.ssh/id_rsa.pub
○​ Copy the output and add it to GitHub → Settings → SSH and GPG keys →
New SSH key.

ssh-rsa
AAAAB3NzaC1yc2EAAAADAQABAAACAQCzzpwymsjqLObGAwCW4XijeK/tVRhiPc1yr/Vwp5
WxiaZDPyZN2nHRO3yp8ceAU8rApdYqItQ7p5E2dnbbSl16dy4DsiuMVV8pjyEJSe6WJV0ykAxS
vX4W2Iecc/a3Jiuuf9VufAoWKGq+6vyivu4PZZxATB1ucGLE0tPqmARo7pC4D3GdgAJYrHubtA
RhEMGMfq7pJFt0NrOVPOxKbEz9R5r9CSnf+tRM0sLkD2AQrb0PnJgif1YXf6s7x/A994CspwrW
h9/zilqR7IGWVnt3iaFWkIO5MbQoViE0cI66qQgWXeupsg95WXgUAw/KgMQSg404EnYBn5dN9
Bncpj89ZKhugusEEB09uLLpDr+oAB9ORKw+vqiS+7QKBYafkT+lhKhRksPDWk/v6YClqdj2dg42
8BDWO2KQM321ofOkhJ9PcsFx3J6A/Ahe1MlMTo5o+zFGf2QNKgT0pSTD5bW3DCnUO8PWg
dLQ5DjUiiVbU5twhSTaOwG+CYJ3jeAaE8DEylcr/oe0Hm+sWVI41dEfpE7M6VbixDUejb6sbj8JG
UcSo9051XqO2kUDFpYr3n63jOp8u9tzIOfqJS1Z+8C73+GcVsVcCHQmSo/cGnDLAdYeIrD5N1
DLpEJsC//FAUrV/niXi6Nq+Mqtb+Unhp/bJMXkju+dbQ6T1xirsvYipw==
galinrasimharao@gmail.com

4.​ Test the connection:​


ssh -T git@github.com​
You should see a success message.

🎯 Next Step: Proceed to Step 3: Clone GitHub Repository & Push Code 🚀

Step 3: Clone GitHub Repository & Push Code

✅ Step 3.1: Clone Repository


1.​ Navigate to your project directory in Windows or WSL.​
cd /mnt/c/Users/YourName/Projects/
2.​ Clone the repository:​
git clone git@github.com:YourUsername/Devips.git​
(Replace YourUsername with your actual GitHub username.)
3.​ Navigate into the cloned repository:​
cd Devips

✅ Step 3.2: Add and Commit Changes


1.​ Add your project files:​
git add .
2.​ Commit the changes:​
git commit -m "Initial project setup"

✅ Step 3.3: Push Changes to GitHub


1.​ Push your code to the repository:​
git push origin main
2.​ Verify your changes on GitHub.

Step 4: Configure Ansible Inventory & Playbook

✅ Step 4.0: Create an Azure Virtual Machine (VM)


1️⃣ Log in to Azure Portal

1.​ Go to Azure Portal.


2.​ Sign in with your Azure account.

2️⃣ Create a Virtual Machine (VM)

1.​ Click "Create a resource" → Choose "Virtual Machine".


2.​ Select Subscription & Resource Group
○​ Subscription: (Choose your existing subscription)
○​ Resource Group: (Create a new one or use an existing one)
3.​ Enter VM Details
○​ Virtual Machine Name: devips-vm
○​ Region: (Choose the nearest region)
○​ Image: Ubuntu 22.04 LTS
○​ Size: Standard B1s (1vCPU, 1GB RAM) (or higher if needed)
4.​ Administrator Account
○​ Authentication Type: SSH Public Key
○​ Username: azureuser
○​ Generate a new SSH key (Copy and save it!)

3️⃣ Configure Networking

1.​ Under "Networking," ensure Allow SSH (22) is enabled.


2.​ Leave other options as default.

4️⃣ Review & Create

1.​ Click "Review + Create"


2.​ Click "Create"
3.​ Wait for the VM deployment to finish.
4.​ When you see the popup asking to select a new key pair, choose:​
"Generate a new key pair" if you don't have an existing key.​
Download and save the private key (.pem file).​
Move it to your WSL home directory:​
mv /mnt/c/Users/YourName/Downloads/my-key.pem ~/.ssh/id_rsa​
chmod 600 ~/.ssh/id_rsa

5️⃣ Find Your VM IP Address

1.​ Go to Virtual Machines in Azure.


2.​ Click on your VM Name (devips-vm).
3.​ Copy the Public IP Address from the Overview page.

6️⃣ Test SSH Connection from WSL

Run this command in WSL to check connection:

ssh azureuser@<your-vm-ip>
(Replace <your-vm-ip> with the copied Public IP Address.)

Yes, since you got the message "permanently added" and then "connection closed", it means
your SSH key was added successfully, but the connection might have closed automatically.

To confirm that everything is set up correctly before moving to Step 4.1, try running the SSH
command again:

ssh azureuser@<your-vm-ip>

Yes, since you got the message "permanently added" and then "connection closed", it means
your SSH key was added successfully, but the connection might have closed automatically.

If it connects successfully, you can proceed to Step 4.1: Create Ansible Inventory File as
planned

If The "Permission denied" error means there is an issue with the SSH key authentication.

Alternative: Add SSH Key via Azure VM Settings

Go to Azure Portal → Navigate to your Virtual Machine.

Click on "Run command" (found in the left-side menu under Operations).

Select "RunShellScript" and enter the following command:

bash

Copy

Edit

mkdir -p ~/.ssh

echo "<your-public-ssh-key>" >> ~/.ssh/authorized_keys

chmod 600 ~/.ssh/authorized_keys

chmod 700 ~/.ssh


cat ~/.ssh/id_rsa.pub

Replace <your-public-ssh-key> with the output from:

Click "Run" and wait for it to complete.

You might also like