mod.rs 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. #[cfg(target_os = "dragonos")]
  2. use drstd as std;
  3. use std::fs::File;
  4. use std::{eprint, eprintln, os::fd::AsFd, print, println, process::Child, vec::Vec};
  5. pub mod unit_manager;
  6. use std::io::Read;
  7. use std::os::unix::io::{AsRawFd, FromRawFd};
  8. pub use unit_manager::*;
  9. use crate::executor::ExitStatus;
  10. pub struct Manager;
  11. impl Manager {
  12. /// ## 检查处于运行状态的unit状态
  13. pub fn check_running_status() {
  14. let mut running_manager = RUNNING_TABLE.write().unwrap();
  15. let mut dead_unit: Vec<usize> = Vec::new();
  16. let mut exited_unit: Vec<(usize, ExitStatus)> = Vec::new();
  17. for unit in running_manager.into_iter() {
  18. let proc = unit.child();
  19. match proc.try_wait() {
  20. //进程正常退出
  21. Ok(Some(status)) => {
  22. //TODO:交付给相应类型的Unit类型去执行退出后的逻辑
  23. println!("Service exited success");
  24. exited_unit.push((
  25. *unit.id(),
  26. ExitStatus::from_exit_code(status.code().unwrap()),
  27. ));
  28. //退出后从表中去除该任务
  29. dead_unit.push(*unit.id());
  30. }
  31. //进程错误退出(或启动失败)
  32. Err(e) => {
  33. eprintln!("unit error: {}", e);
  34. //test
  35. exited_unit.push((*unit.id(), ExitStatus::from_exit_code(!0)));
  36. //从表中去除该任务
  37. dead_unit.push(*unit.id());
  38. }
  39. //进程处于正常运行状态
  40. _ => {}
  41. }
  42. }
  43. //释放锁,以便后续删除操作能拿到锁
  44. drop(running_manager);
  45. //从表中清除数据
  46. for id in dead_unit {
  47. UnitManager::remove_running(id);
  48. }
  49. if UnitManager::running_count() == 0 {
  50. let unit = UnitManager::pop_a_idle_service();
  51. match unit {
  52. Some(unit) => {
  53. let _ = unit.lock().unwrap().run();
  54. }
  55. None => {}
  56. }
  57. }
  58. // 交付处理子进程退出逻辑
  59. // TODO:先不做此处理,因为DragonOS的fork进程管道问题尚未解决
  60. // for tmp in exited_unit {
  61. // let unit = UnitManager::get_unit_with_id(&tmp.0).unwrap();
  62. // unit.lock().unwrap().after_exit(tmp.1);
  63. // }
  64. }
  65. }