FreeVM虚拟化快速安装

1.下载FreeVM虚拟化平台的ISO安装文件,下载并安装UltraISO软件。

下载地址:https://www.freevm.com

2.运行UltraISO软件,选择“文件”菜单,点击“打开”选项,在弹出的对话框中选择您下载的FreeVM虚拟化平台的ISO文件。

3.选择“启动”菜单,点击“写入硬盘映像”选项。

在弹出的对话框中硬盘驱动器选择您需要安装ISO的U盘

4.进行“写入”操作。

注意:该操作会格式化U盘,请提前备份您的文件!

等待写入完成,您就可以将U盘插入需要安装FreeVM虚拟化平台的计算机上。

5.开机时按下相应的键(通常是F2、Delete、F10或Esc键)进入计算机的BIOS设置界面。

在BIOS设置界面中,寻找启动选项(Boot),并选择UEFI启动模式。具体的菜单和选项名称可能会因不同计算机品牌和型号而有所不同。

6.确保将U盘设置为第一启动设备,并保存更改后退出BIOS设置界面。
7.计算机将从U盘启动,并进入FreeVM虚拟化平台的安装界面,回车选择安装FreeVM。

8.使用↑↓选择合适的硬盘进行安装。

9.等待安装完成后回车重启并拔出U盘。

如果计算机有多个硬盘,请确保安装FreeVM的硬盘为启动项第一项

10.等待系统启动。

11.系统首次启动会进行初始化并重启。

12.输入账号密码进入后台,默认为config/config。

[0]网络配置
[1]查询网络配置
[2]密码设置
[3]重置VLAN
[4]重置访问控制
[5]关闭所有引擎
[6]修复磁盘
[7]显示网卡
[8]重启系统

13.修改WEB地址,按数字0。输入IP地址回车,子网掩码回车,网关回车。

14.打开浏览器,输入修改后的地址https://ip

15.点击高级,继续访问,输入用户名密码,默认为admin/admin。

16.阅读最终用户协议,同意后进行密码修改。

17.右上角退出登录,输入修改后的用户名密码进行登录。

默认后台账号密码:config/config
默认WEB地址:https://192.168.1.252

至此FreeVM安装完成!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
将echo命令最后一行的exit()替换为`return 0`后,运行echo命令会出现如下错误提示: ``` $ echo test echo test panic: initproc: not sleeping cpuid = 0 ``` 这个错误提示是在`panic()`函数中打印的,该函数定义在`/kernel/proc.c`文件中,具体的打印语句是在该函数的第7行。 出现这种状况的原因是,在xv6中,每个进程都有自己的用户栈和内核栈。当进程结束时,会调用`exit()`函数,该函数会在用户栈中设置返回值并跳转到内核栈中的`trap()`函数,然后进一步调用`panic()`函数,打印上述错误信息。 而我们将exit()替换为`return 0`后,虽然也会在用户栈中设置返回值,但并不会跳转到内核栈中的`trap()`函数,因此就会出现上述错误。 为了解决这个问题,我们需要在`exit()`函数中,将返回值传递给`wait()`函数,并在`wait()`函数中进行处理。我们可以添加一个新的全局变量`int wait_return_code`,在`exit()`函数中将返回值赋值给该变量,然后在`wait()`函数中对该变量进行判断。修改后的代码如下: ```c int wait_return_code = 0; void exit(void) { struct proc *curproc = myproc(); struct proc *p; int fd; if(curproc == initproc) panic("init exiting"); // Close all open files. for(fd = 0; fd < NOFILE; fd++){ if(curproc->ofile[fd]){ fileclose(curproc->ofile[fd]); curproc->ofile[fd] = 0; } } begin_op(); iput(curproc->cwd); end_op(); curproc->cwd = 0; acquire(&ptable.lock); // Parent might be sleeping in wait(). wakeup1(curproc->parent); // Pass abandoned children to init. for(p = ptable.proc; p < &ptable.proc[NPROC]; p++){ if(p->parent == curproc){ p->parent = initproc; if(p->state == ZOMBIE) wakeup1(initproc); } } // Jump into the scheduler, never to return. curproc->state = ZOMBIE; wait_return_code = curproc->xstate; sched(); panic("zombie exit"); } int wait(void) { struct proc *p; int havekids, pid; acquire(&ptable.lock); for(;;){ // Scan through table looking for zombie children. havekids = 0; for(p = ptable.proc; p < &ptable.proc[NPROC]; p++){ if(p->parent != myproc()) continue; havekids = 1; if(p->state == ZOMBIE){ // Found one. pid = p->pid; kfree(p->kstack); p->kstack = 0; freevm(p->pgdir); p->state = UNUSED; p->pid = 0; p->parent = 0; p->name[0] = 0; p->killed = 0; p->xstate = 0; wait_return_code = 0; release(&ptable.lock); return pid; } } // No point waiting if we don't have any children. if(!havekids || myproc()->killed){ release(&ptable.lock); return -1; } // Wait for children to exit. (See wakeup1 call in proc_exit.) sleep(myproc(), &ptable.lock); //DOC: wait-sleep } } ``` 我们在`exit()`函数中将当前进程的返回值赋值给全局变量`wait_return_code`,在`wait()`函数中根据`wait_return_code`的值进行判断,如果为0,则正常结束,不打印提示信息;否则,打印原来的错误信息。 修改后的echo命令代码如下: ```c #include "kernel/types.h" #include "user/user.h" int main(int argc, char *argv[]) { int i; for (i = 1; i < argc; i++) { printf("%s ", argv[i]); } printf("\n"); if (argc < 2) { return 0; } if (strcmp(argv[argc - 1], "0x88") == 0) { return 0x88; } else { return 0; } } ``` 修改后的代码运行结果如下: ``` $ echo test echo test panic: initproc: not sleeping cpuid = 0 $ echo test 0x88 echo test 0x88 ``` 可以看到,如果返回值为0,程序正常结束,没有任何提示信息;如果返回值为0x88,则打印原来的错误信息。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值