实战演示bacula软件备份功能

简介:

一、实例演示bacula的完全备份功能

1.创建卷组
执行如下命令,连接到bacula控制端,执行备份恢复操作:
 

 
  1. [root@baculaserver opt]#/opt/bacula/sbin/bconsole  
  2. Connecting to Director 192.168.12.188:9101  
  3. 1000 OK: f10-64-build-dir Version: 3.0.2 (18 July 2009)  
  4. Enter a period to cancel a command  
  5. *label  
  6. Automatically selected Storage: dbsd  
  7.  
  8. Enter new Volume name: cicro4   #卷组名称,可随意指定,指定完毕后会在  
  9. #bacula-dir.conf文件的指定位置生成一个cicro4文件  
  10. Defined Pools:  
  11.      1: dbpool  
  12.      2: Scratch  
  13. Select the Pool (1-2): 1  #指定卷组的放置位置,即为SD名称。  
  14. #Dbpool在bacula-dir.conf中定义  
  15. Connecting to Storage daemon dbsd at 192.168.12.188:9103 ...  #由于指定SD在  
  16. #192.168.12.188主机上,因此将卷cicro4创建到了此主机上  
  17. Sending label command for Volume "cicro4" Slot 0 ...  
  18. 3000 OK label. VolBytes=191 DVD=0 Volume="cicro4" Device="dbdev" (/cicro/backup2)  
  19. Catalog record for Volume "cicro4", Slot 0  successfully created.  
  20. Requesting to mount dbdev ...  
  21. 3906 File device "dbdev" (/cicro/backup2) is always mounted.  

2.利用run命令执行备份操作
下面继续在bacula控制端执行备份操作:
 

 
  1. *run  
  2. A job name must be specified.  
  3. The defined Job resources are:   
  4.      1: Client1  #这里的Client1 是在bacula-dir.conf中定义的一个Job执行任务  
  5.      2: Client   #这里的Client 也是在bacula-dir.conf中定义的一个Job执行任务  
  6.      3: BackupCatalog  
  7.      4: RestoreFiles  
  8. Select Job resource (1-2): 1  
  9. Run Backup job  
  10. JobName:  Client1  
  11. Level:    Incremental  
  12. Client:   dbfd  
  13. FileSet:  dbfs  
  14. Pool:     dbpool (From Job resource)  
  15. Storage:  dbsd (From Job resource)  
  16. When:     2009-08-21 13:40:13  
  17. Priority: 10  
  18. OK to run? (yes/mod/no): yes  
  19. Job queued. JobId=67 

到此为止,可以开始执行备份,在bacula-dir.conf文件中定义的Client1是一个增量备份,因此这个备份只是个增量操作。由于这是第一个备份,因此默认Client1会做一个完全备,第二次备份时,才执行增量备份。
 

3.查看备份状态
在bacula控制端利用“status”可以查看bacula的各种状态,这里查看备份时Director端的一个状态信息。
 

 
  1. *status  
  2. Status available for:  
  3.      1: Director  
  4.      2: Storage  
  5.      3: Client  
  6.      4: All  
  7. Select daemon type for status (1-4): 1  
  8. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  9. Daemon started 21-Aug-09 13:22, 0 Jobs run since started.  
  10.  Heap: heap=241,664 smbytes=82,242 max_bytes=82,498 bufs=245 max_bufs=250 
  11.  
  12. Scheduled Jobs:  
  13. Level          Type     Pri  Scheduled          Name               Volume 
  14. ===============================================================================  
  15. Incremental    Backup    10  21-Aug-09 23:05    Client1                cicro4  
  16. Running Jobs:  
  17. Console connected at 21-Aug-09 13:37  
  18.  JobId Level   Name                       Status 
  19. ======================================================================  
  20. 67 Full    Client1.2009-08-21_13.40.16_07 is running  
  21. 由此可知,备份正在进行,备份完成再次查看备份信息,输出如下:  
  22. *status  
  23. Status available for:  
  24.      1: Director  
  25.      2: Storage  
  26.      3: Client  
  27.      4: All  
  28. Select daemon type for status (1-4): 1    
  29. 由于这里bacula将备份的存储端(SD)和控制端(DIR)设置在一台服务器上,因此可以通过选项1“Director”来查看SD的状态,如果SD端和DIR端不在一台服务器上,要查看选项2,即“Storage”。这里选择选项1r后输出内容如下:  
  30. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  31. Daemon started 21-Aug-09 13:22, 1 Job run since started.  
  32.  Heap: heap=241,664 smbytes=73,891 max_bytes=84,825 bufs=212 max_bufs=250 
  33.  
  34. Scheduled Jobs:  
  35. Level          Type     Pri  Scheduled          Name               Volume 
  36. ===============================================================================  
  37. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  38.  
  39. Running Jobs:  
  40. Console connected at 21-Aug-09 13:42  
  41. No Jobs running.  
  42. Terminated Jobs:  
  43.  JobId  Level    Files      Bytes   Status   Finished        Name   
  44. ====================================================================  
  45.     58  Incr          2    46.85 M  OK       19-Aug-09 16:51 Client1  
  46.     59  Incr          2    3.908 M  OK       19-Aug-09 16:51 Client1  
  47.     60  Incr          2    8.377 K   OK       19-Aug-09 16:52 Client1  
  48.     61  Incr          1         0   OK       19-Aug-09 16:53 Client1  
  49.     62  Incr          2    8.344 K   OK       19-Aug-09 16:53 Client1  
  50.     63  Incr          2    8.377 K   OK       19-Aug-09 16:54 Client1  
  51.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  52.     65                1         0  OK       19-Aug-09 16:58 RestoreFiles  
  53.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  54. 67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  55.  

这里可以看到,JobId为67的备份是一个完全备份,备份数据的文件数为25个,备份压缩后的大小为145.5MB,备份完成在“21-Aug-09 13:41”,最后的Client1是备份资源的名称。


二、实例演示bacula的增量备份功能

在上面的操作中,设定的备份资源Job本身就是一个增量备份,下面执行的备份操作与上面完全相同,不同的是,这里是第二次备份,bacula会按照设定执行增量备份,操作如下代码清单如下所示。
 执行增量备份

 
  1. * run  
  2. Automatically selected Catalog: MyCatalog  
  3. Using Catalog "MyCatalog"  
  4. A job name must be specified.  
  5. The defined Job resources are:  
  6.      1: Client1  
  7.      2: Client  
  8.      3: BackupCatalog  
  9.      4: RestoreFiles   
  10. Select Job resource (1-2): 1  
  11. Run Backup job  
  12. JobName:  Client1  
  13. Level:    Incremental  
  14. Client:   dbfd  
  15. FileSet:  dbfs  
  16. Pool:     dbpool (From Job resource)  
  17. Storage:  dbsd (From Job resource)  
  18. When:     2009-08-21 14:20:24  
  19. Priority: 10  
  20. OK to run? (yes/mod/no): yes  
  21. Job queued. JobId=68 
  22. *status  
  23. Status available for:  
  24.      1: Director  
  25.      2: Storage  
  26.      3: Client  
  27.      4: All  
  28. Select daemon type for status (1-4): 1  
  29. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  30. Daemon started 21-Aug-09 13:22, 2 Jobs run since started.  
  31.  Heap: heap=241,664 smbytes=84,576 max_bytes=97,749 bufs=218 max_bufs=252 
  32.  
  33. Scheduled Jobs:  
  34. Level          Type     Pri  Scheduled          Name               Volume 
  35. ===============================================================================  
  36. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  37.  
  38. Running Jobs:  
  39. Console connected at 21-Aug-09 14:19  
  40. No Jobs running.  
  41.  
  42. Terminated Jobs:  
  43.  JobId  Level    Files      Bytes   Status   Finished        Name   
  44. ====================================================================  
  45.     59  Incr          2    3.908 M  OK       19-Aug-09 16:51 Client1  
  46.     60  Incr          2    8.377 K  OK       19-Aug-09 16:52 Client1  
  47.     61  Incr          1         0   OK       19-Aug-09 16:53 Client1  
  48.     62  Incr          2    8.344 K  OK       19-Aug-09 16:53 Client1  
  49.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  50.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  51.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  52.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  53.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  54. 68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  55.  

从最后的备份列表可以看出,系统进行了增量备份,“3.908 M”就是上次备份与这次备份之间的数据增加量。而JobId =68这个备份的Level级别为Incr也说明了此次备份为增量备份。

三、实例演示bacula的差异备份功能

差异备份与增量备份的原理,前面已经介绍过了,这里只给出具体的操作步骤。
 

1.开始执行备份
 

 
  1. *run  
  2. Automatically selected Catalog: MyCatalog  
  3. Using Catalog "MyCatalog"  
  4. A job name must be specified.  
  5. The defined Job resources are:  
  6.      1: Client1  
  7.      2: Client  
  8.      3: BackupCatalog  
  9.      4: RestoreFiles  
  10. Select Job resource (1-4): 2   #这里有两个Job任务可选,名为Client1的为增量  
  11. #备份操作,名为Client的为差异备份操作  
  12. Run Backup job  
  13. JobName:  Client  
  14. Level:    Differential  
  15. Client:   dbfd  
  16. FileSet:  dbfs  
  17. Pool:     dbpool (From Job resource)  
  18. Storage:  dbsd (From Job resource)  
  19. When:     2009-08-21 14:31:04  
  20. Priority: 10  
  21. OK to run? (yes/mod/no): yes  
  22. Job queued. JobId=69 
  23. You have messages.  
  24. 至此,开始执行差异备份,如果备份的数据量较大,可能需要一段时间才能完成备份。下面可以用“status”指令查看备份的状态。  
  25. 2.查看备份状态  
  26. *status  
  27. Status available for:  
  28.      1: Director  
  29.      2: Storage  
  30.      3: Client  
  31.      4: All  
  32. Select daemon type for status (1-4): 1  
  33. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  34. Daemon started 21-Aug-09 14:30, 0 Jobs run since started.  
  35.  Heap: heap=253,952 smbytes=67,810 max_bytes=68,066 bufs=267 max_bufs=272 
  36.  
  37. Scheduled Jobs:  
  38. Level          Type     Pri  Scheduled          Name               Volume 
  39. ===========================================================================  
  40. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  41. Incremental    Backup    10  21-Aug-09 23:05    Client             cicro4  
  42. Incremental    Backup    10  21-Aug-09 23:05    BackupCatalog      cicro4  
  43.  
  44. Running Jobs:  
  45. Console connected at 21-Aug-09 14:30  
  46.  JobId Level   Name                       Status 
  47. ======================================================================  
  48.     69 Full    Client.2009-08-21_14.31.10_03 is running  
  49. Terminated Jobs:  
  50.  JobId  Level    Files      Bytes   Status   Finished        Name   
  51. ====================================================================  
  52.     59  Incr          2    3.908 M  OK       19-Aug-09 16:51 Client1  
  53.     60  Incr          2    8.377 K  OK       19-Aug-09 16:52 Client1  
  54.     61  Incr          1         0   OK       19-Aug-09 16:53 Client1  
  55.     62  Incr          2    8.344 K  OK       19-Aug-09 16:53 Client1  
  56.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  57.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  58.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  59.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  60.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  61.     68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  62. 从上面可以看到,备份还没有完成,备份状态为running。  
  63. 等待几分钟,再次查看备份状态如下:  
  64. * status  
  65. Status available for:  
  66.      1: Director  
  67.      2: Storage  
  68.      3: Client  
  69.      4: All  
  70. Select daemon type for status (1-4): 1  
  71. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  72. Daemon started 21-Aug-09 14:30, 1 Job run since started.  
  73.  Heap: heap=253,952 smbytes=65,680 max_bytes=78,853 bufs=240 max_bufs=274 
  74.  
  75. Scheduled Jobs:  
  76. Level          Type     Pri  Scheduled          Name               Volume 
  77. ==========================================================================   
  78. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  79. Incremental    Backup    10  21-Aug-09 23:05    Client             cicro4  
  80. Incremental    Backup    10  21-Aug-09 23:05    BackupCatalog      cicro4  
  81.  
  82. Running Jobs:  
  83. Console connected at 21-Aug-09 14:30  
  84. No Jobs running.  
  85.  
  86. Terminated Jobs:  
  87.  JobId  Level    Files      Bytes   Status   Finished        Name   
  88. ====================================================================  
  89.     60  Incr          2    8.377 K  OK       19-Aug-09 16:52 Client1  
  90.     61  Incr          1         0   OK       19-Aug-09 16:53 Client1  
  91.     62  Incr          2    8.344 K  OK       19-Aug-09 16:53 Client1  
  92.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  93.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  94.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  95.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  96.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  97.     68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  98.     69  Full         26    149.4 M  OK       21-Aug-09 14:32 Client  
  99. 从这里可以看到,JobId为69的备份已经完成,并且是一个完全备份,备份文件大小为149.4MB,而完成此差异备份的Job任务名称是Client。  
  100. 3.继续执行备份操作  
  101. 在执行下面的操作前,首先在客户端FD需要备份的文件夹下(根据前面的配置可知,应该是/cws3)增加一个大小为3.8MB左右的文件。  
  102. * run     
  103. A job name must be specified.  
  104. The defined Job resources are:  
  105.      1: Client1  
  106.      2: Client  
  107.      3: BackupCatalog  
  108.      4: RestoreFiles  
  109. Select Job resource (1-4): 2  
  110. Run Backup job  
  111. JobName:  Client  
  112. Level:    Differential  
  113. Client:   dbfd  
  114. FileSet:  dbfs  
  115. Pool:     dbpool (From Job resource)  
  116. Storage:  dbsd (From Job resource)  
  117. When:     2009-08-21 14:34:25  
  118. Priority: 10  
  119. OK to run? (yes/mod/no): yes  
  120. Job queued. JobId=70 
  121. *status  
  122. Status available for:  
  123.      1: Director  
  124.      2: Storage  
  125.      3: Client  
  126.      4: All  
  127. Select daemon type for status (1-4): 1  
  128. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  129. Daemon started 21-Aug-09 14:30, 2 Jobs run since started.  
  130.  Heap: heap=253,952 smbytes=67,989 max_bytes=81,162 bufs=240 max_bufs=274 
  131.  
  132. Scheduled Jobs:  
  133. Level          Type     Pri  Scheduled          Name               Volume 
  134. ===========================================================================  
  135. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  136. Incremental    Backup    10  21-Aug-09 23:05    Client             cicro4  
  137. Incremental    Backup    10  21-Aug-09 23:05    BackupCatalog      cicro4  
  138.  
  139. Running Jobs:  
  140. Console connected at 21-Aug-09 14:30  
  141. No Jobs running.  
  142.  
  143. Terminated Jobs:  
  144.  JobId  Level    Files      Bytes   Status   Finished        Name   
  145. ====================================================================  
  146.     61  Incr          1         0   OK       19-Aug-09 16:53 Client1  
  147.     62  Incr          2    8.344 K  OK       19-Aug-09 16:53 Client1  
  148.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  149.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  150.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  151.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  152.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  153.     68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  154.     69  Full         26    149.4 M  OK       21-Aug-09 14:32 Client  
  155.     70  Diff          2    3.908 M  OK       21-Aug-09 14:34 Client  
  156.  

从JobId为70的备份信息可以看出,此备份为差异增量备份,此次进行差异备份的数据量大小刚好为3.908 MB,与前面增加的文件大小基本相同。
为了证明是前面执行的是差异增量备份,在FD端需要备份的文件夹下再次增加一个大小为3.8MB左右的一个文件,继续执行以下备份操作:
 

 
  1. *run  
  2. A job name must be specified.  
  3. The defined Job resources are:  
  4.      1: Client1  
  5.      2: Client  
  6.      3: BackupCatalog  
  7.      4: RestoreFiles  
  8. Select Job resource (1-4): 2  
  9. Run Backup job  
  10. JobName:  Client  
  11. Level:    Differential  
  12. Client:   dbfd  
  13. FileSet:  dbfs  
  14. Pool:     dbpool (From Job resource)  
  15. Storage:  dbsd (From Job resource)  
  16. When:     2009-08-21 14:34:59  
  17. Priority: 10  
  18. OK to run? (yes/mod/no): yes  
  19. Job queued. JobId=71 
  20. *status  
  21. Status available for:  
  22.      1: Director  
  23.      2: Storage  
  24.      3: Client  
  25.      4: All  
  26. Select daemon type for status (1-4): 1  
  27. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  28. Daemon started 21-Aug-09 14:30, 3 Jobs run since started.  
  29.  Heap: heap=253,952 smbytes=69,087 max_bytes=82,260 bufs=240 max_bufs=274 
  30.  
  31. Scheduled Jobs:  
  32. Level          Type     Pri  Scheduled          Name               Volume 
  33. ===========================================================================  
  34. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  35. Incremental    Backup    10  21-Aug-09 23:05    Client             cicro4  
  36. Incremental    Backup    10  21-Aug-09 23:05    BackupCatalog      cicro4  
  37.  
  38. Running Jobs:  
  39. Console connected at 21-Aug-09 14:30  
  40. No Jobs running.  
  41.  
  42. Terminated Jobs:  
  43.  JobId  Level    Files      Bytes   Status   Finished        Name   
  44. ====================================================================  
  45.     62  Incr          2    8.344 K  OK       19-Aug-09 16:53 Client1  
  46.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  47.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  48.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  49.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  50.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  51.     68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  52.     69  Full         26    149.4 M  OK       21-Aug-09 14:32 Client  
  53.     70  Diff          2    3.908 M  OK       21-Aug-09 14:34 Client  
  54.     71  Diff          3    7.817 M  OK       21-Aug-09 14:35 Client  
  55.  

由JobId为71的备份可以看出,此次备份的大小为7.817 M,刚好是上次差异增量备份的大小与此次增加文件的大小之和,由此证明确实为差异备份。
第三次在FD端需要备份的文件夹下增加一个大小为3.8M左右的一个文件,继续执行备份操作:
 

 
  1. *run  
  2. A job name must be specified.  
  3. The defined Job resources are:  
  4.      1: Client1  
  5.      2: Client  
  6.      3: BackupCatalog  
  7.      4: RestoreFiles  
  8. Select Job resource (1-4): 2  
  9. Run Backup job  
  10. JobName:  Client  
  11. Level:    Differential  
  12. Client:   dbfd  
  13. FileSet:  dbfs  
  14. Pool:     dbpool (From Job resource)  
  15. Storage:  dbsd (From Job resource)  
  16. When:     2009-08-21 14:35:32  
  17. Priority: 10  
  18. OK to run? (yes/mod/no): yes  
  19. Job queued. JobId=72 
  20. *status  
  21. Status available for:  
  22.      1: Director  
  23.      2: Storage  
  24.      3: Client  
  25.      4: All  
  26. Select daemon type for status (1-4): 1  
  27. f10-64-build-dir Version: 3.0.2 (18 July 2009) x86_64-unknown-linux-gnu redhat   
  28. Daemon started 21-Aug-09 14:30, 4 Jobs run since started.  
  29.  Heap: heap=253,952 smbytes=69,087 max_bytes=82,260 bufs=240 max_bufs=274 
  30.  
  31. Scheduled Jobs:  
  32. Level          Type     Pri  Scheduled          Name               Volume 
  33. ===========================================================================  
  34. Incremental    Backup    10  21-Aug-09 23:05    Client1            cicro4  
  35. Incremental    Backup    10  21-Aug-09 23:05    Client             cicro4  
  36. Incremental    Backup    10  21-Aug-09 23:05    BackupCatalog      cicro4  
  37.  
  38. Running Jobs:  
  39. Console connected at 21-Aug-09 14:30  
  40. No Jobs running.  
  41.  
  42. Terminated Jobs:  
  43.  JobId  Level    Files      Bytes   Status   Finished        Name   
  44. ====================================================================  
  45.     63  Incr          2    8.377 K  OK       19-Aug-09 16:54 Client1  
  46.     64                3    77.44 K  OK       19-Aug-09 16:57 RestoreFiles  
  47.     65                1         0   OK       19-Aug-09 16:58 RestoreFiles  
  48.     66                2    38.77 K  OK       19-Aug-09 16:59 RestoreFiles  
  49.     67  Full         25    145.5 M  OK       21-Aug-09 13:41 Client1  
  50.     68  Incr          2    3.908 M  OK       21-Aug-09 14:20 Client1  
  51.     69  Full         26    149.4 M  OK       21-Aug-09 14:32 Client  
  52.     70  Diff          2    3.908 M  OK       21-Aug-09 14:34 Client  
  53.     71  Diff          3    7.817 M  OK       21-Aug-09 14:35 Client  
  54.     72  Diff          4    11.72 M  OK       21-Aug-09 14:35 Client  
  55.  

第三次执行备份,从JobId为72的备份可以很清楚地看出差异备份与增量备份的差别。
















本文转自南非蚂蚁51CTO博客,原文链接:http://blog.51cto.com/ixdba/832080 ,如需转载请自行联系原作者


相关文章
|
7月前
|
存储 设计模式 前端开发
怎么根据MVC开发规则进行开发
MVC开发规则,也称为MVC设计模式,是软件工程中一种常用的架构模式,用于将应用程序划分为三个主要组成部分:模型(Model)、视图(View)和控制器(Controller)。这种架构模式有助于将应用程序的逻辑、数据和用户界面分离,使代码更加清晰、可维护,并且提高了应用程序的灵活性。
63 2
SAP SD基础知识之与FI集成相关的流程与配置
SAP SD基础知识之与FI集成相关的流程与配置
|
Android开发 Java
CC框架实践(1):实现登录成功再进入目标界面功能
用CC来AOP地实现登录成功后再跳转到目标界面功能
1573 0