Custom services blocklist
By default, Migrate to Containers disables unneeded services on a VM when you migrate it to a container. These services can sometimes cause issues with the migrated container, or are not needed in a container context.
You can also define your own custom list of services to disable in a migrated container by using a custom blocklist. With a blocklist, you specify one or more services to disable in a migrated container.
Defining the blocklist
Define your customized blocklist in a .yaml file, in the form:
service_list:
  - name: <var>group-name-1</var>
    services:
      - <var>service-name</var>
  - name: <var>group-name-2</var>
    services:
      - <var>service-name</var>
      - <var>ervice-name</var>
Where:
- Groups are a logical collection of services so that you can collect similar services in a single group. Specify any string value for the group name.
- The service name specifies the service to disable in the migrated container.
For example, define the file my-blocklist.yaml as:
service_list:
  - name: lvm-related
    services:
      - lvm2-lvmetad
  - name: hardware-related
    services:
      - microcode
      - microcode.ctl
Applying a custom blocklist
Apply your custom blocklist to a container by either:
- Creating a Kubernetes - configmapcontaining the blocklist and adding it to the deployment spec of the container.- This method lets you add the blocklist without having to rebuild the container. However, you have to recreate the - configmapon every cluster used to host the container.
- Edit the Dockerfile for the container and rebuild the container image. - This method requires you to rebuild the container image to add the blocklist. Because the blocklist is now included in the container there is no need to perform any additional configuration on the cluster before deployment. 
Using a configmap
To create a blocklist by using a configmap:
- Migrate the source VM to a container. 
- Create a blocklist .yaml file as shown above that lists the service you want to disable. In this example, name the file - my-blocklist.yaml.
- Create a - configmapfrom the blocklist .yaml file:- kubectl create configmap configmap-name --from-file=path-to-yaml - In this example, the configmap is called - blocklistcm:- kubectl create configmap blocklistcm --from-file=./my-blocklist.yaml 
- View the configmap: - kubectl describe configmaps 
- Edit the - deployment_spec.yamlcreated when you migrated the container:- vi deployment_spec.yaml 
- In the deployment spec, add the following: - Add a new volume for the - configmapunder- volumes:- volumes: - configMap: name: blocklistcm # Name of the config map you created above. name: blocklistvol # Name of the configmap volume.
- Add a volume mount for the configmap: - spec: containers: volumeMounts: - mountPath: /etc/bl # Mount path for the configmap volume. name: blocklistvol # Name of the configmap volume.
- Add a new environment variable named - HC_CUSTOM_SERVICE_BLOCKLISTspecifying the path to the blocklist .yaml file. The name of the environment variable is required to be- HC_CUSTOM_SERVICE_BLOCKLIST:- containers: - image: container-image-location env: - name: HC_CUSTOM_SERVICE_BLOCKLIST value: "/etc/bl/my-blocklist.yaml"- The path specified by value is the concatenation of the mountPath of the configmap and the name of the blocklist .yaml file, - my-blocklist.yaml.
- Save the file. 
 
- Deploy the container: - kubectl apply -f deployment_spec.yaml 
- After the container is deployed, you can then examine the container to ensure that the services are not running. For example: - # Get pod name. $ kubectl get pod # Connect to pod. $ kubectl exec -it POD_NAME -- /bin/bash # View running services. This step is OS dependent. For example: $ service --status-all```
Editing the Dockerfile
This section describes how to create a custom blocklist by editing the Dockerfile created by the migration.
- Migrate the source VM to a container. 
- Open the Dockerfile in an editor. 
- Add the following - COPYcommand to add the blocklist .yaml file to the filesystem of the container:- COPY src dest - For example: - COPY my-blocklist.yaml /etc/mybl/my-blocklist.yaml - The destination path can be any path within the container. 
- Add a new environment variable named - HC_CUSTOM_SERVICE_BLOCKLISTspecifying the path to the blocklist .yaml file based on the file destination specified by the- COPYcommand. The name of the environment variable is required to be- HC_CUSTOM_SERVICE_BLOCKLIST:- ENV HC_CUSTOM_SERVICE_BLOCKLIST /file-path - For example: - ENV HC_CUSTOM_SERVICE_BLOCKLIST /etc/mybl/my-blocklist.yaml 
- Update the container image. - The way you update the container image depends on your build environment. You can use: - gcloudto build the image and upload it to the Container Registry as described at Quickstart: Build.
- docker buildas described at Build and run your image .
 
- After you build the new image, open the - deployment_spec.yamlfile in an editor to update the image location:- spec: containers: - image: new-image-location - For example, new-image-location could be - gcr.io/my-project/my-new-image:v1.0if you used- gcloudto build the image and uploaded it to the Container Registry.
- Deploy the container: - kubectl apply -f deployment_spec.yaml 
- After the container is deployed, you can then examine the container to ensure that the services are not running. For example: - # Get pod name. $ kubectl get pod # Connect to pod. $ kubectl exec -it POD_NAME -- /bin/bash # View running services. This step is OS dependent. For example: $ service --status-all