UserData
Dữ liệu người dùng (UserData) là nội dung thông tin tùy chỉnh của người dùng được cung cấp cho Server trên hạ tầng cloud hiện đang được triển khai và chạy trên Server đó.
Mục đích là cung cấp thêm dữ liệu cho Server để tùy chỉnh nhiều nhất có thể theo nhu cầu của ta, hạ tầng cloud vServer có hỗ trợ tình năng này.
VNG Cloud cho phép sử dụng các loại dữ liệu nhiều cách khác nhau, Mỗi loại dữ liệu sẽ được xử lý thường là dòng đầu tiên.
Batch
PowerShell
Bash
Python
Cloud config
Khởi tạo UserData khi kích hoạt vServer
Gợi ý điền câu lệnh cho UserData
Batch
rem cmd
File được thực thi ở cmd.exe (có thể được thay bằng biến môi trường COMSPEC.
PowerShell
#ps1 or #ps1_sysnative (system native)
#ps1_x86 (Windows On Windows 32bit)
Câu lệnh PowerShell sử dụng để thực thi như mong muốn.
Bash
#!/bin/bash
Để sử dụng tính năng này, ta cần cài đặt Bash Shell trên hệ thống và sẵn có trên hệ thống môi trường PATH.
Python
#!/usr/bin/env python
Mặc dù Python đã có sẵn theo mặc định khi cài đặt, nhưng nó cũng phải có trong hệ thống môi trường PATH.
Cloud config
#cloud-config
Cấu hình Cloud config được hổ trợ, không bao gồm các nội dung riêng cho Linux. Các hướng dẫn cho việc cấu hình được hỗ trợ như sau:
write_files: Xác định một tập hợp các file mà sẽ được tạo ra trên hệ thống file nội bộ. Nó có thể là một danh sách các mục hoặc chỉ một mục, với các thuộc tính sau:
path: Đường dẫn chính xác tuyệt đối trên ổ đĩa, nơi mà nội dung sẽ được ghi lên.
content: Nội dung mà sẽ được viết vào file đã cho.
permissions: số nguyên đại diện cho quyền truy cập file.
encoding: Mã hóa của dữ liệu trong nội dung . Các mã hóa được hỗ trợ là:
b64, base64 dành cho các nội dung được mã hóa base64;
gz,gzip dành cho các nội dung được én gzip;
gz+b64,gz+base64,gzip+b64,gzip+base64 danh cho các nội dung gzip được mã hóa base64.
Ví dụ:
set_timezone: Thay đổi Múi giờ hệ thống
Ví dụ:
set_hostname: Thay đổi Tên máy chủ
Ví dụ:
groups: Tạo nhóm nội bộ và thêm những user đang tồn tại vào các nhóm đó.
Yêu cầu định dạng của khi tạo nhóm như sau:
<group_name>: [<user1>,<user2>]
Danh sách user có thể để trống, nên có thể tạo một nhóm mà không có user nào.
Ví dụ:
users: Tạo và cấu hình user nội bộ.
Những user được xác định là một danh sách, mỗi thành phần trong danh sách là đại diện cho một user. Mỗi user có thể được xác định bởi những thuộc tính sau:
name: (chuỗi bắt buộc điền): Đây là tên đăng nhập username;
gecos: Mô tả ngắn gọn về user;
primary_group: Nhóm chính của user;
groups: Danh sách nhóm của user. Trên Windows, primary_group và groups được ràng buộc nhau.
passwd: Mật khẩu của user. Trên Linux, mật khẩu được lưu trữ ở dạng chuỗi băm, trong khi đó trên Windows thì mật khẩu được lưu trữ dưới dạng văn bản thuần. Nếu không xác định được mật khẩu, hệ thống sẽ đặt mật khẩu ngẫu nhiên.
inactive: giá trị Boolean (true/false) cho biết trạng thái hoạt động của user, mặc định là False. Nếu thiết lập là True, user sẽ bị vô hiệu quá.
expiredate: Ngày hết hạn của tài khoản user, định dạng là chuỗi <year>-<month>-<day>. Ví dụ: 2020-10-01.
ssh_authorized_keys: Danh sách các public keySSH mà sẽ được thiết lập trong ở ~/.ssh/authorized_keys cho phép user đó đăng nhập bằng SSH.
Ví dụ:
ntp: Cấu hình NTP Server, (Network Time Protocol), được định nghĩa với các thuộc tính sau:
enabled: Giá trị Boolean (True/False), mặc định là True, để cấu hình tắt bật NTP;
servers: Danh sách các máy chủ NTP;
pools: Danh sách các nhóm máy chủ NTP;
Server và pools được gộp chung lại, server là được ưu tiên trước trong danh sách. Trên Windows, không có khác biệt giữa một NTP pool hay server
Ví dụ:
runcmd: Được chỉ dẫn là nơi có thể chứa danh sách các câu lệnh mà sẽ được thực thi, theo thứ tự được xác định.
Một câu lệnh có thể được xác định là một chuỗi ký tự hay một danh sách chuỗi ký tự, với phần tử đầu tiênlà đường dẫn đến tập tin thực thi.
Trên Windows, các dòng lệnh được tập hợp lại trong một file và được thực thi với cmd.exe.
Ví dụ:
#cloud-configruncmd: - 'dir C:\\' - ['echo', '1']
Theo chỉ thị, cloud config được thực thi theo thứ tự mặc định như sau:
write_files: Tạo và ghi nội dung vào file được xác định;
set_timezone: Cài đặt múi giờ;
set_hostname: Thay đổi tên máy chủ của Server;
ntp: Cấu hình mấy chủ NTP để đồng bộ hóa thời gian
groups: Tạo vả quản lý nhóm user nội bộ;
users: Tạo và cấu hình tài khoản người dùng nội bộ;
runcmd: Cahy5 các lệnh được cung cấp trong quá trình khởi tạo
Có thể dùng tùy chọn là cloud_config_plugins để lọc hoặc thay đổi thứ tự các plugin cloud-config.
Việc thực thi việc đổi tên máy chủ set_hostname hay chạy các câu lệnh runcmd có thể cần được khổi động lại Server nếu cần. Việc khởi động lại sẽ được thực hiện sau khi tất cả các chỉ thị được thực thi.
Khởi tạo UserData khi kích hoạt vServer
Để nhập các dòng lệnh để thực hiện việc cung cấp UserData cho Server thì bạn có thể thực hiện ở bước Khởi tạo Server (Bước 4 ở Trải nghiệm sản phẩm vServer ở đây) như sau:
Tại bước cấu hình "Network setting" để thực hiện việc cấu hình nhập UserData thì ta sẽ chọn tùy chọn "UserData" như hình bên dưới.
Ta có thể tải lên (upload) file hoặc điền những câu lệnh vào field nội dung để thực thi việc cung cấp thông tin user vào Server. Tham khảo ở bên dưới mục "Gợi ý điền câu lệnh cho UserData", VNG Cloud cung cấp gợi ý mặc định câu lệnh scripts để tiện việc cấu hình UserData.
Nếu thông tin người dùng UserData ở các tools đang sử dụng đã được mã hóa Base64 thì ta sẽ chọn vào "User Data is base64 encoded".
Gợi ý điền câu lệnh cho UserData
Khi tạo Server Windows, VNG Cloud cung cấp đoạn câu lệnh mặc định (Default Scripts) ngay tại trường User Data, bao gồm cả thông tin bản quyền hệ điều hành Windows mà ta có thể sử dụng ngay:
#ps1
net user stackops VngP@ssword2
/logonpasswordchg:yes /y
net localgroup administrators stackops /add
Set-ItemProperty -Path "HKLM:\SYSTEM\CurrentControlSet\Control\Terminal*Server\WinStations\RDP-TCP\" -Name PortNumber -Value 3490
net stop TermService /y
net start TermService /y
netsh advfirewall firewall add rule name="RDP-3490"
dir=in action=allow protocol=TCP localport=3490
w32tm /config /syncfromflags:manual /manualpeerlist:time.windows.com
w32tm /config /update
w32tm /resync /nowait
cscript.exe slmgr.vbs /ipk N69G4-B89J2-4G8F4-WWYCC-J464C
cscript.exe slmgr.vbs /skms kms.vngcloud.vn
cscript.exe slmgr.vbs /ato
Trong đó với các thông tin:
stackops VngP@ssword2 : là Username và password của OS;
N69G4-B89J2-4G8F4-WWYCC-J464C : là key kích hoạt bản quyền (activation key) của OS, hệ thống sẽ tự động tham chiếu (mapping) theo key và OS tương ứng:
Kết quả hiển thị sẽ được hiển thị mặc định như sau trên giao diện người dùng:
Lưu ý
Việc sử dụng license của Windows được xác thực theo IP mà VM đã mua license, từ đó hệ thống sẽ kích hoạt bản quyền.
Last updated