Abstract

With the rapid development of Internet of Things technology, a large amount of user information needs to be uploaded to the cloud server for computing and storage. Side-channel attacks steal the private information of other virtual machines by coresident virtual machines to bring huge security threats to edge computing. Virtual machine migration technology is currently the main way to defend against side-channel attacks. VM migration can effectively prevent attackers from realizing coresident virtual machines, thereby ensuring data security and privacy protection of edge computing based on the Internet of Things. This paper considers the relevance between application services and proposes a VM migration strategy based on service correlation. This strategy defines service relevance factors to quantify the degree of service relevance, build VM migration groups through service relevance factors, and effectively reduce communication overhead between servers during migration, design and implement the VM memory migration based on the post-copy method, effectively reduce the occurrence of page fault interruption, and improve the efficiency of VM migration.

1. Introduction

With the development of the Internet of Things technology, the number of Internet of Things devices is increasing rapidly, which means that a large amount of data will be generated for processing and storage. Due to the limited computing and storage capabilities of IoT devices, these data are usually uploaded to a cloud server for processing. However, the long-distance data transmission of ordinary cloud computing is difficult to meet the needs of resource-intensive and delay-sensitive IoT applications [1]. As a result, edge computing was created. Edge computing delivers ultra-low latency and high bandwidth for IoT devices to satisfy the data processing and storage requirements by putting computing and storage resources on the network edge near the IoT devices [2, 3]. The massive data generated by the Internet of Things devices in the edge computing-based IoT will contain a large amount of user identity information, location information, and sensitive information, so leakage of user information will inevitably pose significant security risks to users [4].

In edge computing, the most common method of information leakage is through side-channel attack. Malicious users use the underlying shared resources of the server to build a side channel, bypassing the logical isolation provided by the virtualized environment, and stealing the private information of other coresident virtual machines [5]. Rather than focusing on the mapping between plaintext and ciphertext, side-channel attacks obtain keys by analyzing nonfunctional behaviors and encryption or decryption operations [6, 7]. As a result, the commonly used strong encryption schemes cannot avoid exposing this physical information, posing a significant threat to the data security and privacy protection of edge computing-based IoT. Therefore, defense against side-channel attacks is crucial for edge computing. At the moment, virtual machine migration technology is frequently used to defend against side-channel attacks, which is the primary method of defense [8, 9]. Compared with traditional countermeasures, the VM migration method is general and immediately deployable [10]. By dynamically migrating virtual machines, the time for coexistence between virtual machines is reduced, thereby reducing the amount of information that an attacker steals from the target virtual machine, so that the attacker cannot successfully obtain the target’s information. Virtual machine migration can effectively prevent attackers from realizing coresident virtual machines, thereby ensuring data security and privacy protection of edge computing-based IoT [11].

As the types of IoT services increase, and their functions become more complex, a service request often requires a combination of services on multiple virtual machines. Therefore, if the association between services is not considered in the process of virtual machine migration, it will bring a large amount of communication overhead between servers and increase network energy consumption to the cloud data center. Therefore, this paper designs a virtual machine migration strategy based on service relevance, defines server relevance factors to quantify the degree of relevance between services, and migrates more relevant virtual machines to the same target server according to the degree of relevance between services. A post-copy method based on service priority is also designed to minimize the total migration time, and page fault rate. The experiment proved that the virtual machine migration strategy based on service relevance minimizes the communication overhead between servers while achieving fast and efficient VM migration.

Virtual machine migration technology mainly involves server resource monitoring, load forecasting, virtual machine placement methods, and memory migration execution. In the process of VM live migration, firstly select the VM to migrate and the target server through the virtual machine placement method in the migration scheduling phase, and then complete the VM migration through the memory migration method in the migration execution phase. At present, there are many research studies on VM migration technology, which mainly focus on VM placement method and VM memory migration method.

2.1. VM Placement Methods

Virtual machine placement methods are mainly divided into migration time selection, virtual machine selection, and target server selection.

For the migration time selection problem, the prediction method is generally used to predict the resource utilization rate of the server in the future. For example, Melhem et al. [12] proposed a host load detection algorithm to determine overload or light load and migrate VMs to achieve server consolidation or load balancing.

For the VM selection and target server selection problem, Sotiriadis et al. [13] proposed an adaptive VM scheduling algorithm. The algorithm selects the VM to migrate by analyzing real-time resource monitoring data and migrates the VM to the server with the highest server evaluation value. In order to reduce the communication overhead caused by migration, Liu et al. [14] proposed a correlation-based VM migration algorithm to quantify the relationship between the resource requirements of VMs and time-varying resources, build the VM group with the highest relevance as the migration unit, and select the server with the least relevance to the virtual group as the target server. Rajabzadeh and Haghighat [15] selected the VM with the highest CPU utilization without sacrificing SLA and used the Markov chain model to select the target server. In order to reduce the resource consumption caused by migration, Xu and Fortes [16] considered the total resource waste, power consumption, and cooling cost of the VM when it was running. However, the relationship between VMs and the cost of live migration is not fully considered. In literature [17], Verma et al. considered energy consumption and migration costs, but their research showed that it is difficult to estimate the exact power consumption of the server. A novel VM placement algorithm [18] designed a new technology called resource usage factor, which can be used to quantify server resource usage and place VMs on suitable physical machines to improve the resource utilization of physical machines. In addition, Kanniga Devi et al. [19, 20] also did research on optimizing placement methods. They used cluster intelligent algorithms to optimize the selection of VMs or target servers in VM migration strategies, reducing energy consumption in cloud computing and improving Resource utilization rate.

2.2. VM Memory Migration Methods

The research of memory migration methods mainly focuses on the pre-copy method and the post-copy method [21].

Mandal et al. [22] designed an algorithm to find the appropriate bandwidth and the number of prereplication iterations. It develops a model to measure network resource consumption, migration time, and downtime and determine the appropriate migration bandwidth and number of prereplication iterations to improve performance. In order to reduce the total migration data, the paper [23] proposed a method to optimize the pre-copy method, which can reduce unnecessary memory page transfer, and the feature-based compression (CBC) algorithm reduces the total migration time and downtime. In order to ensure that the memory migration is completed within a specific time, Zhang et al. [24] proposed a novel transmission control mechanism to ensure the bandwidth of the calculation and theoretically analyzed the bandwidth demand to ensure the total migration time and downtime. Literature [25] conducts a comprehensive empirical study on the pre-copy method to provide suggestions for optimal selection. To optimize post-copy method, Su et al. [26] improved the subsequent copy method by eliminating unnecessary remote page errors.

Sun et al. [27] proposed an improved serial migration strategy, which is based on the post-copy method and supports multivirtual machine migration. Lei et al. [28] proposed a hybrid copy method, which combines the pre-copy method with the subsequent copy method to make up for the defects of the pre-copy method and the post-copy method, but this method still has page fault. Deshpande et al. [29] designed an eviction-aggregation VM live migration method. It speeds up the eviction time of the VM migration process by setting the cache area and restores the overloaded server to the normal state in the fastest time.

At present, when selecting multiple VMs for migration, the research on VM selection seldom considers the communication consumption between the VMs. If closely related VMs are migrated to different servers, it will bring more data transmission overhead between servers in the calculation process. This paper defines service relevance factor to quantify the degree of relevance between services and proposes a VM selection strategy based on service relevance. It combines closely connected VMs into a VM migration group for migration to reduce energy consumption and communication overhead. For memory migration methods, this paper chooses to improve the post-copy method and proposes a post-copy memory migration method based on service priority (PBSCP). The method sets the initial priority of the service based on service relevance and updates the service priority according to the page fault situation to reduce the occurrence of page fault interruption. This method also reduces the migration time and the migration data volume by adding temporary storage devices and reduces the occurrence of page faults.

3. The Design of Virtual Machine Migration Strategy

3.1. Service Relevance Factor

Figure 1 describes the communication relationship between devices in the Edge Computing. Users and IoT devices upload the collected data to the edge server through the network for processing and storage, and then the VMs on the server provide services to users and IoT devices, so the edge server will generate interserver communication overhead due to the cooperation between services. The dynamic nature of multiple service relationships affects the communication overhead between servers in the process of VM migration. Before designing VM selection and memory migration strategies based on service relevance, we need to quantify the degree of association between services, which determines the value of the service relevance factor.

This paper defines the service relevance factor as the degree of relevance between application service programs on each VM. Before measuring the degree of association, the interaction rate between application services and the communication overhead of each interaction need to be considered. The service set is defined as , and there are different interaction rates and communication overheads between services.

Assume that service on virtual machine and service on virtual machine have an interaction relationship when providing services to users. The interaction rate factor is defined as , which represents the number of interactions required to process service requests per second. According to the interaction factor, define the server overhead consumed by two related services aswhere represents the cost of processing each interactive task.

Since a VM can contain multiple services, the relationship between services is also different. If there is no interaction between services, the service overhead is 0. Therefore, the calculation formula of service relevance factor can be expressed as

3.2. VM Selection Strategy Based on Service Relevance

A virtual machine migration strategy is based on the relevance of services against side-channel attacks, a VM group with a higher association is built through the service relevance factor, and the VM migration group is used as a whole for migration. From the perspective of service relevance, the VM migration group is a closely connected “area” on the server. Migrating this whole to the target server can improve task execution efficiency and reduce network communication overhead between servers.

During the construction and expansion of the VM migration group, the VM with the highest relevance within the group should be found. Therefore, in the process of building a VM migration group, it is necessary to compare the service relevance between a certain VM and the migration group, and the service relevance between this VM and outside the group.

This paper defines to indicate the association between VM and VM migration group . The calculation of can be expressed as

According to the calculation formula of service relevance factor (2), it can be seen that the server cost between any two VMs is shown in the following formula:

Formula (4) can be further expressed as

Set the server overload threshold . If the service load exceeds the threshold, it will be regarded as an overload state, in order to facilitate the measurement of the load condition that the server can accept when it is not overloaded. The load capacity of the server is defined as .

In this paper, the VM selection strategy is the construction process of the VM migration group. When determining the amount of migration, find the VM with the largest load on the original server as the initial migration group, and then expand the initial migration group to include more load.

During the expansion process, the VM with the closest relationship to the group must be selected each time, and the load of this VM and the load of the migration group must be calculated whether the total load reaches the migration data volume. If the required volume of migration data is not reached, the VM is added to the group; otherwise, the next closest VM is selected, and the process is repeated until the load of the migration group meets the requirements. The specific strategy is shown in Figure 2.

Assuming that the load to be migrated for original server is , the acceptable load difference threshold is , the VM on is denoted as , the VM migration group constructed is , and the construction algorithm of the VM migration group is as shown in Algorithm 1.

Input: server load information
  Output: VM migration group G
  Method:
(1) Analyze the server load information to get the original server as ;
(2) Get the set of virtual machines on as AllVmList, set to ;
(3) Calculate the VM load on , mark it as , and sort in descending order of load;
(4) Initialize the VM migration group G;
(5)while(! = null) do
(6)  find the VM with and set it as ;
(7)   ;
(8)  if () then
(9)    add to G;
(10)    if then
(11)     return VM migration group G;
(12)    else
(13)     break;
(14)    end if
(15)   end if
(16)  end while
(17)  while(! = null) then
(18)   select in , that is, select the VM with the most service relevance and set it to ;
(19)   ;
(20)   if() then
(21)    add to G;
(22)    if () then
(23)     break;
(24)    else
(25)     continue;
(26)    end if
(27)   end if
(28)  end while
(29)return VM migration group G;
3.3. Memory Migration Strategy Based on Service Priority

The VM migration group constructed based on service relevance has the characteristics of large data volume and many service requests. This paper combines service relevance and designs a post-copy memory migration method (PCBSP) based on service priority. The method uses service priority to determine the corresponding memory page push priority and adds temporary storage devices (TD) during the migration process to make the migration time minimize and reduce the page fault rate.

3.3.1. Overall Process of PCBSP

In order to minimize the VM migration time and reduce the page fault rate, PCBSP adds a memory page push algorithm based on service priority and temporary storage devices on the basis of the post-copy method. The basic process of PCBSP is shown in Figure 3.

PCBSP mainly includes three stages. The first phase needs to select the appropriate spare memory construction in the physical server. The second phase is the VM migration phase, which includes migrating memory pages to and sending memory pages directly to the target server.

The third phase is the VM migration phase, which includes the migration of memory pages from and the direct acquisition of required memory pages from the original server. The migration of memory pages is collectively called the memory page push.

3.3.2. Priority Calculation

Since multiple services can be deployed on a VM, that is, the VM migration group contains several services, and each service provides a service when the user requests it, there may be dependent or dependent relationships among multiple services. In this paper, a memory page push algorithm (PBSP) based on service priority is designed to actively push memory pages to reduce the occurrence of page fault in the target server.

When the VM is resumed on the target server, the initial priority of the service and related pages is calculated according to the service request rate and the dependency relationship between the services.

Definition 1. (service rate). For a certain service in the VM migration group G, the number of requests received from users per unit time is taken as the service rate, which is recorded as .
Figure 4 is an example graph of an associated service group. Services are represented by dots in the graph, and service dependencies are represented by directed edges in the graph.

Definition 2. According to the dependency between services in the associated service group, define the set of service nodes, which is a dependence of service as and the set of service nodes, which is dependent on as .
Set the default priority of Service aswhere represents a parameter that can simplify to an integer.
Each service performs related functions and needs to load the corresponding program into the memory.
Through this loading mechanism, the corresponding page fault rate can be inferred according to the probability of service access. Therefore, when calculating the preset priority, the service priority and the related memory page priority can be equivalent. Thus, the default priority of memory pages related to can be obtained:For a service, which is being dependent on, the greater its out-degree, the greater the , and the priority push of its related pages can prevent page faults due to the lack of dependent services when users request the service, which is being dependent on, which can effectively reduce the page fault rate. This paper comprehensively considers the in-degree and out-degree of the service and defines the initial priority calculation method for the service and its related pages:For page fault service , when the VM resumes running on the target server, first check whether there are any memory pages for service , and if so, push the memory pages according to the initial priority calculated by (8).
The priority of memory page push is mainly determined by , , and . Since and are fixed amounts, the service rate is an average value for a period of time, which is not related to the interaction sequence. If the interaction rate is low, but the access is earlier, according to the priority, it may not be pushed first, and page faults will eventually occur. Therefore, the priority needs to be dynamically adjusted according to the real-time situation of service access during the memory migration process.
In order to dynamically adjust the priority, this paper introduces the following parameters: , , and , where represents the change value of the priority related to page faults when the original server receives a page fault request, represents the priority update cycle, and represents the memory page priority array that has not yet been migrated to , and represents the memory page priority array on .
The and priority update methods are the same, and the two arrays are collectively referred to as .
Set the index of memory page in the priority array as , service of , and if there is no page fault request related to service within , the priority is reduced asIf a page fault request for a service related to occurs within T, the page faulted service is . If this service is a dependence of the service in , the priority is increased toIf this service is dependent on the service in , the priority is increased toBecause once a page fault occurs, as a dependence service, there is a high probability of a page fault.

3.3.3. Implementation of PBSP

When a large number of page faults occur in the restored VM, it directly requests memory pages from the original server. At this time, the page fault transmission is directly transmitted from the original server to the target server in descending order of the initial priority. The remaining memory pages in adjust their priority dynamically and actively push memory pages to in descending order of priority.

The memory page push algorithm () based on service priority is given in Algorithm 2.

  Input: initial list
  Output:
  Method:
(1) Receive page faults request;
(2) Send pages to target server;
(3).delete (pages);
(4) Service  = getService (page);//get service related to fault page.
(5)for each page in unMigrationPages do//unMigrationPages are pages unmigrated.
(6)  Service  = getService (page);
(7)  if ( is related to ) then
(8)   if ( replay on ) then
(9)    ;
(10)   else
(11)    ;
(12)   end if
(13)  else
(14)  ;
(15)  end if
(16)end for
(17)return;

4. Implementation

This section mainly introduces the overall process of the VM migration strategy based on service relevance and introduces the VM selection strategy based on service relevance in the migration scheduling phase and the specific implementation of the memory migration method based on service priority in the memory migration phase.

4.1. Overall Process

The overall process of VM live migration is divided into two phases, namely, the migration scheduling phase and the migration execution phase. In this paper, the VM selection strategy based on service relevance is applied to the migration scheduling module, and the memory migration method based on service priority is applied to the migration execution module. The overall framework of VM live migration is shown in Figure 5.

The main process is divided into two phases: the migration scheduling phase and the migration execution phase. The migration scheduling phase mainly involves VM selection and the target server selection, and the migration execution phase mainly involves memory migration.

4.2. Implementation of Migration Scheduling Phase

The migration scheduling phase is mainly divided into two parts. Firstly, the load that needs to be migrated is calculated according to the original server’s own load information and builds the VM migration group. Then, the target server is selected to place the VM migration group according to the load information of other servers provided by the VM migration management center. The selection of VMs is the key to migration scheduling. This paper uses a VM selection strategy based on service relevance to construct a VM migration group. The process of the migration scheduling phase is shown in Figure 6.Step 1: after the server management center detects the migration command, it starts the construction of the VM migration group and builds the VM migration group G according to the service relevance as the load group that needs to be migrated. Then, send a VMM request [Req] to the VMM management center.Step 2: after the idle server receives the VMM request information, it calculates its own failure rate, load capacity, and other information.Step 3: the idle server returns the reply message [reply] to the original server.Step 4: if the original server is adjacent to the idle server, that is, there is a TCP link, send a reply message [reply] directly to the original server; otherwise, establish a new link first, and then send [reply] to the server.Step 5: the original server receives [reply], selects the appropriate target server according to the load information of the idle server, and prepares to enter the migration execution phase.

4.3. Implementation of the Migration Execution Phase

The migration execution phase mainly performs VM migration. The first step is to establish a temporary storage device to calculate the service priority according to formula (8). The second step is to directly send the original server to the target server and migrate the memory page to the TD through the running state of the VM. In the third step, the target server moves out the memory page from the TD and obtains the required memory page from the original server. The second and third steps are carried out at the same time and are collectively referred to as memory page push. Figure 7 shows the process of the migration execution phase.

Next, the specific implementation process of the migration execution phase is described in detail:Step 1: the original server obtains the resource usage of each server from the VMM manager and obtains the candidate server list of TD according to the result of the migration scheduling stage. Select some physical servers in the list as TD, which can be used by overloaded servers to quickly move out of VMs and move in memory pages to the target server.Step 2: send the minimum execution conditions such as the execution status of each VM in the VM migration group directly to the target server and resume the execution of the VM on the target server.Step 3: move the memory pages in the VM migration group into the TD in the order of service priority. If the VM migrated on the target server has a page fault interruption at this time, it directly requests the memory page from the original server, and the original server sends the page fault to the target server and, at the same time, updates the order in which the VM memory page is pushed. Repeat this process until all the memory in the VM is sent to the TD.Step 4: the target server migrates the memory pages in the TD to the server in the order of service priority. This process is synchronized with the third step. If a page fault occurs after the end of the third step, a memory page is directly requested from the TD. Repeat this process until the target server finishes receiving memory.

5. Results Analysis

5.1. Experimental Protocol

In the experiment, this paper uses a total of 6 PCs based on the actual situation, of which one is used as a VMM management node to deploy migration management strategies, and the other 5 are used as edge nodes. The configuration of each PC is shown in Table 1.

The Eucalyptus cloud computing platform is open source, easy to use, and rich in management interfaces [30]. This article uses the Eucalyptus architecture to build the above devices into a cluster system. In this experiment, the management node is set as the VM migration manager, and the VMs are run on edge nodes to simulate providing services to terminal devices. This article deploys the VM placement method and memory migration method on the system to implement the VM migration framework. The topology of the final cluster is shown in Figure 8.

All VMs in the system use KVM/QEMU 1.6.50, running Ubuntu as a suboperating system, with 2 virtual CPUs (vCPU), and each VM is configured with different memory sizes such as 512M, 1024M, 2G, etc.

In order to verify the effectiveness of the VM migration strategy based on service relevance, the experiment was divided into four groups, and the following questions were tested, respectively:(1)Whether the strategy can reduce the communication overhead between servers?(2)Whether the strategy can load balance quickly?(3)Whether the memory migration method of this policy is efficient?

5.2. Analysis of Results

Experiment 1. This experiment is to verify the effectiveness of the VM placement method based on service relevance (SRVMP) and simulate the round-robin scheduling (RR) algorithm [31], the least connection (LC) algorithm [32], and the ant colony (AG) algorithm [33]. In order to compare the communication overhead of each algorithm, this paper divides each algorithm into single VM migration (single) and multiple VM migration (multiple). The experimental comparison chart is shown in Figure 9. It can be seen from Figure 9 that the communication overhead of the SRVMP algorithm is much smaller than that of the RR algorithm and the LC algorithm, and the communication overhead of multivirtual machine RR algorithm is lower than single-virtual machine RR algorithm, and multivirtual machine LC algorithm has lower communication overhead than single-virtual machine LC algorithm. This is because multivirtual machine migration algorithm migrates multiple VMs to the same server, which avoids the communication overhead caused by VMs being scattered to different servers. The SRVMP algorithm considers the service relevance between VMs during multivirtual machine migration and groups closely related VMs into a migration group. Therefore, the SRVMP algorithm designed in this paper can reduce the communication overhead between servers during migration.

Experiment 2. Experiment 2 needs to test the load balancing ability and task execution time of the system, and the combined result of the two is used as a measure of the effectiveness of load balancing.
The load balancing capability is measured by the load balance degree. The load balance degree refers to the standard deviation between the server resource utilization and the average data center resource utilization, which reflects the system load distribution. And the smaller the degree is, the more balanced the load is. The calculation formula is as follows:where represents the load balance degree, represents the total number of servers in the data center, represents the resource utilization of the servers , and denotes the average utilization of the data center resources.
The task execution time indicates the duration from entering the processing queue to completing the task processing. This paper mainly takes the form of randomly generating multiple tasks, such as generating the number of tasks at regular intervals and then recording the results of several time units. In the task processing time experiment, the efficiency of different algorithms is verified by different task numbers. Besides, so as to avoid accidental factors, the average is taken as the final result through 30 experiments.
The algorithms in this experiment are all based on multivirtual machine migration, and on the basis of Experiment 1, a self-heuristic algorithm ant colony (AG) algorithm is added for comparison. The results of the experiment are shown in Figure 10.
According to Figure 10(a), we can see that the SRVMP algorithm is relatively evenly distributed in the CPU load balance degree. Although it is lower than the AG algorithm, the load balancing degree is roughly distributed around 10. The reason for this phenomenon is that this paper uses the greedy strategy to chooses the server with the least migration cost as the target server, so the communication cost and other indicators are not optimal. Comparing the RR algorithm and the LC algorithm, the algorithm in this paper has a greater advantage in load balance degree. Similarly, Figures 10(b) and 10(c) also prove that the SRVMP algorithm can achieve system load balancing. Since the AG algorithm has a higher balance degree, this paper will do an experiment to check the execution time of the task. The experimental result is shown in Figure 11.
It can be seen from Figure 11 that the SRVMP algorithm proposed in this paper has a greater advantage in task execution time. When the number of tasks is small, there is not much difference in the execution time, but when the number of tasks gradually increases, the execution time of the RR algorithm and the LC algorithm increases significantly. The time complexity of the SRVMP algorithm is , the time complexity of the ant colony algorithm is , and is the number of iterations of the ant colony algorithm. The AG algorithm requires multiple iterations. Therefore, although the SRVMP algorithm is slightly worse than the AG algorithm in system load balancing, it does not affect the task execution speed.

Experiment 3. The VM migration strategy based on service relevance designed in this paper uses an improved post-copy method (optimized post-copy) PCBSP to perform memory migration.
This experiment compares PCBSP with pre-copy and post-copy and uses total migration time (TMT), total migrated data, and page fault conditions as the criteria for verifying the efficiency of the method [34].

5.2.1. Total Migration Time (TMT)

We set the target server’s memory in the form of virtual memory in the form of 8G, 10G, 12G, 14G, and 16G and checked the changes of TMT in the four methods. The experimental results are shown in Figure 12.

Figure 12 shows that as the target server memory gets larger, the memory pressure gets smaller and smaller, and the TMT gap of each method gradually decreases. As can be seen from the figure, pre-copy takes the longest time, post-copy takes slightly shorter time, and post-copy (Active Push) further shortens the total time, because post-copy (Active Push) combines active push of memory and on-demand requests for memory to speed up the migration speed. The optimized post-copy method used in this article takes slightly longer than post-copy (Active Push). This is because the optimized post-copy method needs to first migrate the memory pages to TD and then to the target server.

5.2.2. Total Migrated Data

In this experiment, the original server and the target server were kept unchanged, and we compared the changes in the amount of migrated data, respectively, when the number of VMs is 1, 2, 3, 4, and 5. Since post-copy and post-copy (Active Push) have roughly the same amount of migrated data, the experiment compared the amount of migrated data by pre-copy, post-copy, and optimized post-copy methods. Figure 13 shows the comparison of the transferred data volume of the three methods. In the figure, the pre-copy transferred data volume is the largest, because the pre-copy method needs to repeatedly transfer the dirty pages synchronously, while the post-copy method only needs to migrate the memory page once. The optimized post-copy method takes into account the problem of data redundancy, so the amount of transferred data is the least, reducing the migration overhead, and effectively improving the efficiency of VM migration.

5.2.3. Page Fault Interruption

In order to show the trade-off between MT and migration performance, select a suitable VM to be migrated as the database server, query the database content through Yahoo Cloud Servicing Benchmark (YCSB) [35], and calculate each data based on the data calculated by YCSB. The number of operations per second is used to measure migration performance. This paper shows the changes in the number of operations per second of several methods over time. According to continuous monitoring of migration performance, the effect is shown in Figure 14.

The figure shows that, from about 110 seconds, the post-copy-related methods have always remained at a low level from the beginning of the migration. This is caused by a large number of page faults. At this time, the request for page faults and the target server receives memory pages to compete for traffic. The performance of the pre-copy method will also decline, but the decline is relatively gentle, because the pre-copy method does not have the effect of page faults. We compared it with the other two post-copy methods; the method in this paper recovers faster. Although the performance of the post-copy method decreases less, the MT is the longest. We consider that the application background of this paper is to complete the VMM as quickly as possible, so the trade-off between MT and migration performance should choose MT as a more important performance indicator when the migration performance is acceptable.

In summary, the post-copy memory migration method based on service priority proposed in this chapter can indeed reduce the VM migration time and reduce the occurrence of page faults when the migration performance is less affected; that is, it can quickly and efficiently complete VM migration.

6. Conclusion

Edge computing-based IoT provides a platform for data calculation and storage for the IoT devices. The data generated by IoT devices contains a large amount of user identity information, location information, and sensitive information. Therefore, data security and privacy issues in edge computing-based IoT are becoming increasingly prominent. Side-channel attacks steal the private information of other virtual machines by coresident virtual machines to bring huge security threats to edge computing. Virtual machine migration is the main way to defend against side-channel attacks. When selecting VM for migration, the degree of association between services is not considered. If some closely connected VMs are migrated to different servers, it will bring a lot of communication overhead during the calculation and migration process. In the process of VM memory migration, the pre-copy method is often used, which needs to repeatedly transfer a large number of dirty pages, thereby increasing the migration time of the virtual machine.

For the above problems, this paper proposes a VM migration strategy based on service relevance. First, define the service relevance factor to quantify the degree of relevance between services. Then, design a VM selection strategy based on service relevance, and group closely related VMs into a VM migration group to migrate. Finally, we design a post-copy memory migration method based on service priority (PCBSP); it can quickly migrate out of the VM migration group and effectively reduce the page fault rate. Through comparative experiments, it is verified that the VM selection method based on service relevance can effectively reduce the communication overhead in VM live migration. However, there are still two limitations in this paper. The next step of this paper is as follows: (1) in the VM migration, the downtime caused by server failure or overload is not considered. Once failure or downtime occurs, the VM migration will be invalid, and it is difficult to recover the VM after failure. The next step should consider how to deal with failure or downtime when using this method to migrate VMs. (2) PCBSP only calculates the service priority uniformly according to the dependency and dependent relationship of the service, without considering the specific situation. In the next step, we should consider the specific situation to make the calculation of service priority more accurate and further reduce the page fault rate.

Data Availability

The experimental data of this study are available from the corresponding author upon reasonable request.

Conflicts of Interest

The authors declare that there are no conflicts of interest regarding the publication of this article.

Acknowledgments

This work was supported in part by the Major Projects of Natural Science Research in Universities in Jiangsu Province under Grant 17KJA413001.