X-Git-Url: https://code.grnet.gr/git/ganeti-local/blobdiff_plain/fd22ce8ef81cf23858a0446dcc0c4781a9427b65..24e1140f1c0f75e21ddb4219faca09f57da602cd:/hbal.hs diff --git a/hbal.hs b/hbal.hs index a69622a..d54951a 100644 --- a/hbal.hs +++ b/hbal.hs @@ -19,8 +19,9 @@ import qualified Ganeti.HTools.Container as Container import qualified Ganeti.HTools.Cluster as Cluster import qualified Ganeti.HTools.Node as Node import qualified Ganeti.HTools.CLI as CLI -import Ganeti.HTools.Rapi + import Ganeti.HTools.Utils +import Ganeti.HTools.Types -- | Command line options structure. data Options = Options @@ -40,6 +41,18 @@ data Options = Options , optShowHelp :: Bool -- ^ Just show the help } deriving Show +instance CLI.CLIOptions Options where + showVersion = optShowVer + showHelp = optShowHelp + +instance CLI.EToolOptions Options where + nodeFile = optNodef + nodeSet = optNodeSet + instFile = optInstf + instSet = optInstSet + masterName = optMaster + silent a = (optVerbose a) == 0 + -- | Default values for the command line options. defaultOptions :: Options defaultOptions = Options @@ -114,7 +127,6 @@ we find a valid solution or we exceed the maximum depth. iterateDepth :: Cluster.Table -- ^ The starting table -> Int -- ^ Remaining length -> Cluster.NameList -- ^ Node idx to name list - -> Cluster.NameList -- ^ Inst idx to name list -> Int -- ^ Max node name len -> Int -- ^ Max instance name len -> [[String]] -- ^ Current command list @@ -122,7 +134,7 @@ iterateDepth :: Cluster.Table -- ^ The starting table -> Cluster.Score -- ^ Score at which to stop -> IO (Cluster.Table, [[String]]) -- ^ The resulting table and -- commands -iterateDepth ini_tbl max_rounds ktn kti nmlen imlen +iterateDepth ini_tbl max_rounds ktn nmlen imlen cmd_strs oneline min_score = let Cluster.Table ini_nl ini_il ini_cv ini_plc = ini_tbl all_inst = Container.elems ini_il @@ -136,7 +148,7 @@ iterateDepth ini_tbl max_rounds ktn kti nmlen imlen in do let - (sol_line, cmds) = Cluster.printSolutionLine ini_il ktn kti + (sol_line, cmds) = Cluster.printSolutionLine ini_il ktn nmlen imlen (head fin_plc) fin_plc_len upd_cmd_strs = cmds:cmd_strs unless (oneline || fin_plc_len == ini_plc_len) $ do @@ -144,7 +156,7 @@ iterateDepth ini_tbl max_rounds ktn kti nmlen imlen hFlush stdout (if fin_cv < ini_cv then -- this round made success, try deeper if allowed_next && fin_cv > min_score - then iterateDepth fin_tbl max_rounds ktn kti + then iterateDepth fin_tbl max_rounds ktn nmlen imlen upd_cmd_strs oneline min_score -- don't go deeper, but return the better solution else return (fin_tbl, upd_cmd_strs) @@ -161,44 +173,16 @@ formatOneline ini_cv plc_len fin_cv = main :: IO () main = do cmd_args <- System.getArgs - (opts, args) <- CLI.parseOpts cmd_args "hbal" options - defaultOptions optShowHelp + (opts, args) <- CLI.parseOpts cmd_args "hbal" options defaultOptions unless (null args) $ do hPutStrLn stderr "Error: this program doesn't take any arguments." exitWith $ ExitFailure 1 - when (optShowVer opts) $ do - putStr $ CLI.showVersion "hbal" - exitWith ExitSuccess - - (env_node, env_inst) <- CLI.parseEnv () - let nodef = if optNodeSet opts then optNodef opts - else env_node - instf = if optInstSet opts then optInstf opts - else env_inst - oneline = optOneline opts + let oneline = optOneline opts verbose = optVerbose opts - (node_data, inst_data) = - case optMaster opts of - "" -> (readFile nodef, - readFile instf) - host -> (getNodes host >>= readData, - getInstances host >>= readData) - - ldresult <- liftM2 Cluster.loadData node_data inst_data - (loaded_nl, il, csf, ktn, kti) <- - (case ldresult of - Ok x -> return x - Bad s -> do - printf "Error: failed to load data. Details:\n%s\n" s - exitWith $ ExitFailure 1 - ) - let (fix_msgs, fixed_nl) = Cluster.checkData loaded_nl il ktn kti - - unless (null fix_msgs || verbose == 0) $ do - putStrLn "Warning: cluster has inconsistent data:" - putStrLn . unlines . map (\s -> printf " - %s" s) $ fix_msgs + + (fixed_nl, il, csf, ktn, kti) <- CLI.loadExternalData opts let offline_names = optOffline opts all_names = snd . unzip $ ktn @@ -216,13 +200,10 @@ main = do else n) fixed_nl when (Container.size il == 0) $ do - (if oneline then - putStrLn $ formatOneline 0 0 0 - else - printf "Cluster is empty, exiting.\n") + (if oneline then putStrLn $ formatOneline 0 0 0 + else printf "Cluster is empty, exiting.\n") exitWith ExitSuccess - unless oneline $ printf "Loaded %d nodes, %d instances\n" (Container.size nl) (Container.size il) @@ -242,7 +223,7 @@ main = do when (optShowNodes opts) $ do putStrLn "Initial cluster status:" - putStrLn $ Cluster.printNodes ktn nl + putStrLn $ Cluster.printNodes nl let ini_cv = Cluster.compCV nl ini_tbl = Cluster.Table nl il ini_cv [] @@ -268,7 +249,7 @@ main = do nmlen = mlen_fn ktn (fin_tbl, cmd_strs) <- iterateDepth ini_tbl (optMaxLength opts) - ktn kti nmlen imlen [] oneline min_cv + ktn nmlen imlen [] oneline min_cv let (Cluster.Table fin_nl _ fin_cv fin_plc) = fin_tbl ord_plc = reverse fin_plc sol_msg = if null fin_plc @@ -306,7 +287,7 @@ main = do (final_mem, final_disk) = Cluster.totalResources fin_nl putStrLn "" putStrLn "Final cluster status:" - putStrLn $ Cluster.printNodes ktn fin_nl + putStrLn $ Cluster.printNodes fin_nl when (verbose > 3) $ do printf "Original: mem=%d disk=%d\n" orig_mem orig_disk