Thường xuyên cần đăng nhập vào một hệ thống từ xa và chạy một số lệnh hoặc chương trình để lấy kết quả, nhiều phần mềm có thể phục vụ mục đích này như putty và gitshell. Các phần mềm này thường cung cấp quyền truy cập an toàn vào hệ thống từ xa. Nhưng bạn đã bao giờ tự hỏi phải làm gì nếu bạn cần chạy lệnh trên nhiều hệ thống khác nhau cùng một lúc và nhận tất cả các kết quả này trở lại ở một nơi duy nhất? Đặc biệt là trong kỷ nguyên dữ liệu lớn, nhiều tác vụ có thể chạy trên các hệ thống phân tán khác nhau và bạn muốn có một nơi duy nhất để tích lũy kết quả.
Trong bài đăng này, chúng tôi sẽ giới thiệu một thư viện Java có thể giúp đạt được điều này — JSch. Đây là một triển khai SSH2 thuần Java. JSch cho phép bạn kết nối với máy chủ sshd và sử dụng chuyển tiếp cổng, chuyển tiếp X11, chuyển tệp, v.v., và bạn có thể tích hợp chức năng của nó vào các chương trình Java của riêng mình.
Lợi ích của việc sử dụng nó là bạn có thể lập trình kết nối với máy chủ từ xa và thực thi một số lệnh ở đó mà không cần đăng nhập vào nó. Dưới đây là một ví dụ về cách bạn có thể chạy ls -la trên máy chủ Linux từ xa.
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.io.InputStreamReader; import java.util.Properties; import com.jcraft.jsch.Channel; import com.jcraft.jsch.ChannelExec; import com.jcraft.jsch.JSch; import com.jcraft.jsch.Session; public class JSchTest { public static void main(String[] args){ try{ String command = "ls -la"; String host = "host_ip"; String user = "username"; String password = "password"; JSch jsch = new JSch(); Session session = jsch.getSession(user, host, 22); Properties config = new Properties(); config.put("StrictHostKeyChecking", "no"); session.setConfig(config);; session.setPassword(password); session.connect(); Channel channel = session.openChannel("exec"); ((ChannelExec)channel).setCommand(command); channel.setInputStream(null); ((ChannelExec)channel).setErrStream(System.err); InputStream input = channel.getInputStream(); channel.connect(); System.out.println("Channel Connected to machine " + host + " server with command: " + command ); try{ InputStreamReader inputReader = new InputStreamReader(input); BufferedReader bufferedReader = new BufferedReader(inputReader); String line = null; while((line = bufferedReader.readLine()) != null){ System.out.println(line); } bufferedReader.close(); inputReader.close(); }catch(IOException ex){ ex.printStackTrace(); } channel.disconnect(); session.disconnect(); }catch(Exception ex){ ex.printStackTrace(); } } }
Sau khi chạy chương trình, đầu ra là:
Channel Connected to machine hostname server with command: ls -la total 1367872 drwxr-xr-x 33 peter users 4096 Dec 11 16:49 . drwxr-xr-x 6 root root 4096 Mar 21 2014 .. -rw------- 1 peter users 15607 Dec 11 19:01 .bash_history -rw-r--r-- 1 peter users 1177 Mar 21 2014 .bashrc drwxr-xr-x 2 peter users 4096 Sep 12 09:47 bin drwxrwxrwx 2 peter users 4096 Sep 3 14:10 cfg
Khá tiện lợi. Nếu bạn muốn chạy cùng một lệnh trên hai hệ thống từ xa, bạn chỉ cần tạo một phiên và kênh mới và làm tương tự.
JSch có thể giúp làm nhiều việc hơn nữa bao gồm chuyển tiếp cổng, chuyển tệp, v.v.
Hey Sonic,
Great article. That is what i was looking for. Thanks
But i am getting a "com.jcraft.jsch.JSchException: java.net.ConnectException: Connection refused: connect" error.
Any insights here?