Cuttlefish đa người dùng cho phép máy chủ của bạn khởi chạy nhiều thiết bị khách ảo bằng một lệnh gọi khởi chạy duy nhất.
Nhiều máy ảo Cuttlefish này có thể chia sẻ một số tài nguyên ổ đĩa của máy chủ, cho phép bạn tiết kiệm dung lượng ổ đĩa. Mỗi máy ảo sẽ có một lớp phủ ổ đĩa riêng biệt bao gồm các phân vùng Android (chẳng hạn như super
, userdata
, boot
). Mọi nội dung sửa đổi đối với ổ đĩa khách đều được đặt trong lớp phủ ổ đĩa dành riêng cho khách, cung cấp cho mỗi máy ảo Cuttlefish một chế độ xem sao chép khi ghi của các phân vùng ổ đĩa. Khi mỗi thiết bị ảo ghi thêm dữ liệu vào chế độ xem của đĩa, các tệp lớp phủ trên đĩa lưu trữ sẽ tăng kích thước vì các tệp này đang ghi lại delta giữa trạng thái ban đầu và trạng thái hiện tại.
Bạn có thể đặt lại các tệp lớp phủ để đưa ổ đĩa Cuttlefish về trạng thái ban đầu. Quá trình này được gọi là rửa xe bằng nước nóng.
Số lượng thực thể
Các thiết bị Cuttlefish tạo và sử dụng tài nguyên trên máy chủ liên kết với số lượng thực thể của chúng. Ví dụ: một kết nối adb
được hiển thị thông qua ổ cắm máy chủ TCP tại cổng 6520
cho thiết bị Cuttlefish có số thực thể 1
.
Khi nhiều thực thể được khởi chạy, ứng dụng sẽ tạo một ổ cắm máy chủ TCP tại cổng 6520
cho thiết bị đầu tiên, 6521
cho thiết bị thứ hai và tăng số cổng cho mỗi thiết bị bổ sung.
Sửa đổi số lượng thực thể được hỗ trợ tối đa
Các tài nguyên phía máy chủ, chẳng hạn như thiết bị mạng TAP, phải được phân bổ trước cho máy ảo Cuttlefish. Theo mặc định, gói
Debian cuttlefish-base
cung cấp tài nguyên cho các số thực thể 1
thông qua 10
.
Bạn có thể thay đổi điều này bằng cách sửa đổi num_cvd_accounts
trong /etc/default/cuttlefish-host-resources
và khởi động lại dịch vụ cuttlefish-host-resources
bằng cách chạy lệnh sau:
sudo systemctl restart cuttlefish-host-resources
Cấu hình chuẩn
Cấu hình chuẩn đại diện cho cấu hình cho thiết bị Cuttlefish ở định dạng JSON. Bạn có thể tạo tệp JSON cấu hình chuẩn để mô tả cấu hình của nhiều thiết bị Cuttlefish trong trường hợp nhiều người dùng.
Phần sau đây mô tả định dạng dùng cho tệp JSON cấu hình chuẩn hoá (thay thế phần giữ chỗ bằng cấu hình thiết bị).
{
"common": {
CONFIGURATIONS_APPLYING_TO_ALL_DEVICES
},
"instances": [
{
FIRST_DEVICE_CONFIGURATION
},
{
NTH_DEVICE_CONFIGURATION
}
]
}
Sau đây là tệp cấu hình mẫu của một chế độ thiết lập có hai thiết bị, một thiết bị điện thoại và một thiết bị đeo:
{
"instances": [
{
"@import": "phone",
"vm": {
"memory_mb": 8192,
"setupwizard_mode": "OPTIONAL",
"cpus": 4
},
"disk": {
"default_build": "/home/username/devices/cf_x86_64_phone-userdebug"
}
},
{
"@import": "wearable",
"vm": {
"memory_mb": 8192,
"setupwizard_mode": "REQUIRED",
"cpus": 4
},
"disk": {
"default_build": "/home/username/devices/cf_gwear_x86-userdebug"
}
}
]
}
Bảng này mô tả các phần tử được sử dụng trong cấu hình mẫu với hai thiết bị:
Nguyên tố | Loại | Mô tả |
---|---|---|
instances |
Mảng | Mảng các đối tượng JSON, mỗi đối tượng mô tả một thiết bị trong nhóm nhiều người dùng của các thiết bị sẽ được khởi chạy. |
@import |
Chuỗi | Cho biết loại thiết bị và đặt giá trị mặc định cho cấu hình thiết bị. Các loại thiết bị được hỗ trợ là phone và wearable . |
vm |
Đối tượng | Chỉ định các thuộc tính áp dụng cho môi trường máy ảo dành riêng cho thực thể thiết bị. |
memory_mb |
Số | Dung lượng bộ nhớ cần phân bổ cho một máy ảo cụ thể, tính bằng megabyte. |
setupwizard_mode |
Chuỗi | Chỉ định xem trình hướng dẫn thiết lập thiết bị có chạy cho người dùng trong lần chạy đầu tiên của thiết bị hay không. Các tuỳ chọn được hỗ trợ cho chế độ trình hướng dẫn thiết lập là DISABLED , OPTIONAL và REQUIRED . |
cpus |
Số | Số lượng CPU ảo được phân bổ cho máy ảo. |
disk |
Đối tượng | Chỉ định các thuộc tính liên quan đến việc định vị cấu phần phần mềm hệ thống tệp dùng để chạy một thực thể máy ảo. |
default_build |
Chuỗi | Đường dẫn hệ thống tệp cục bộ đến thư mục chứa hình ảnh thiết bị ảo Cuttlefish. |
Để biết thêm ví dụ về các tệp cấu hình được phân phối bằng cvd
, hãy xem thư mục cvd_test_configs
trong cây mã Cuttlefish.
Kiểm soát các phiên bản nhiều người dùng
Phần này mô tả cách tạo và huỷ thiết bị trong trường hợp nhiều người dùng. Bạn có thể chạy nhiều thiết bị Cuttlefish bằng các tuỳ chọn sau:
- Cấu hình chuẩn: Chạy cấu hình tuỳ chỉnh cho từng thiết bị bằng cách sử dụng tệp cấu hình JSON mô tả danh sách các thực thể cần chạy.
- Một hình ảnh khách: Chạy nhiều thiết bị từ một hình ảnh khách.
Khởi động nhiều máy ảo từ cấu hình chính tắc
Để tạo nhiều máy ảo bằng một cấu hình chuẩn mô tả trường hợp nhiều người dùng, hãy gọi lệnh cvd create
với tiền tố cờ --config_file=
như sau:
cvd create --config_file=CONFIG_FILE
Sau đây là ví dụ về lệnh gọi tham chiếu đến một tệp cấu hình chuẩn có tên là /etc/phone.json
.
cvd create --config_file=/etc/phone.json
Khởi động nhiều máy ảo từ một hình ảnh khách
Để khởi chạy nhiều thiết bị Cuttlefish bằng một hình ảnh khách, hãy sử dụng cờ --num_instances=N
, trong đó N là số lượng thiết bị cần khởi chạy. Theo mặc định, các thiết bị bắt đầu từ số thực thể 1
.
cvd create --num_instances=N
Để thay đổi số lượng thực thể bắt đầu, hãy làm theo một trong những cách sau:
Thêm cờ
--base_instance_num=N
với N làm số thực thể đầu tiên.cvd create --base_instance_num=N
Chạy Cuttlefish bằng tài khoản người dùng khớp với
vsoc-NN
, trong đó NN là số thực thể cơ sở ở dạng hai chữ số. Ví dụ: để chạy Cuttlefish bằng tài khoản người dùngvsoc-01
, hãy chạy:cvd create --base_instance_num=1
Cách dừng thiết bị
Để dừng tất cả thiết bị được khởi chạy bằng lệnh gọi cvd create
gần đây nhất, hãy chạy:
cvd stop
Để khởi động lại các thiết bị đã bị dừng, hãy chạy:
cvd start
Để xoá hoàn toàn một thiết bị khỏi quá trình chạy hệ thống, hãy làm như sau:
cvd remove