Azure Ubuntu VM के लिए स्वैप कैसे बनाएं?


9

मैंने इस पर काफी कुछ पोस्ट पढ़े हैं, लेकिन मैं सही दृष्टिकोण के बारे में अभी भी अनिश्चित हूं, यह मानते हुए:

  1. मेरे पास एक डिफ़ॉल्ट उबंटू है 14.04 LTS VM द्वारा बनाया गया है और Azure पर चल रहा है, जो स्वैप के साथ नहीं आता है

  2. मैं अतिरिक्त स्टोरेज का उपयोग करके एक नया डिस्क बनाने के बजाय, मौजूदा VM संग्रहण का उपयोग करके एक स्वैप बनाना चाहूंगा

पोस्ट मैंने पढ़ा है:

कई समाधानों पर चर्चा की गई, लेकिन मुझे ऐसा कोई नहीं मिल रहा है जो सर्वर रिबूट में बना रहेगा (शायद क्लाउड-इन के कारण छवि विभाजन के बारे में खुद का विचार है), क्या कोई मुझे सर्वश्रेष्ठ अभ्यास पर सलाह दे सकता है?

जवाबों:


8

यह मानते हुए कि आपके पास लिनक्स एजेंट स्थापित है। आपको बस इतना करना है कि /etc/waagent.conf के तहत स्वैप सक्षम करना है। ये प्रासंगिक लाइनें हैं:

ResourceDisk.Format=y                   # Format if unformatted. If 'n', resour$
ResourceDisk.Filesystem=ext4            # Typically ext3 or ext4. FreeBSD image$
ResourceDisk.MountPoint=/mnt/resource   #
ResourceDisk.EnableSwap=y               # Create and use swapfile on resource d$
ResourceDisk.SwapSizeMB=2048            # Size of the swapfile.

यह स्वैप बनाने के लिए स्वचालित रूप से संसाधन डिस्क (जो प्रत्येक वीएम के साथ आता है) का उपयोग करेगा। इसके लिए डिस्क बनाने की कोई आवश्यकता नहीं है।

अद्यतन : आपको स्वैप बनाने के लिए नीचे दिए गए चरणों को भी पूरा करना होगा:

umount /mnt
service walinuxagent restart

डिस्क प्रावधान अन्य वितरणों के विपरीत, उबंटू के क्लाउड इनिट द्वारा नियंत्रित किया जाता है। तो नहीं, यह काम नहीं करना चाहिए, और डॉक्टर और मेरा परीक्षण दोनों इसकी पुष्टि करते हैं।
बिटिन

2
मैंने MS समर्थन से संपर्क किया और पाया कि समाधान सेट करना है ResourceDisk.Format, ResourceDisk.EnableSwapऔर ResourceDisk.SwapSizeMB। लेकिन महत्वपूर्ण कदम sudo service walinuxagent restartस्वैप फ़ाइल बनाने के लिए एक मैनुअल करना है, क्योंकि सिर्फ रिबूट करना सर्वर मेरे लिए काम नहीं करता है।
बिटिन

मैं अभी भी इस बारे में पूछ रहा हूं कि क्लाउड इनिट का आंकड़ा इस सब में कैसे है, क्योंकि उनके डॉक और वाजेंट.कॉन्फ टिप्पणी भ्रामक हैं।
बिटिन

हाँ। मुझे माफ कर दो। एजेंट पुनरारंभ को शामिल करना भूल गया। मैंने अपने ubuntu vm पर परीक्षण किया और समस्याओं के बिना काम किया। मैंने जवाब अपडेट कर दिया है। क्‍लाउड-इनिट के बारे में, मुझे नहीं लगता कि इसका स्‍वैपाइल के निर्माण से कोई लेना-देना है क्‍योंकि एजेंट एक ext4 पार्टीशन (/ mnt) के अंदर फाइल बनाता है। यह एक स्वैप विभाजन नहीं बनाता है।
ब्रूनो फारिया

2
Azure गैलरी छवि से निर्मित Ubuntu 14.04 LTS VM पर काम नहीं किया। सभी चरणों को पूरा करने के बाद, swapon -sअभी भी स्वैप फ़ाइलों की खाली सूची दिखाता है।
जस्टमार्टिन

2

ब्रूनो का जवाब एक शानदार शुरुआती बिंदु है, लेकिन यह केवल मैंने रिबूट होने के बाद काम किया और बूटिंग के बाद एक और मिनट दिया।

ए। /etc/waagent.confसंबंधित लाइनों में स्वैप सक्षम करें :

ResourceDisk.Format=y                   # Format if unformatted. If 'n', resour$
ResourceDisk.Filesystem=ext4            # Typically ext3 or ext4. FreeBSD image$
ResourceDisk.MountPoint=/mnt/resource   #
ResourceDisk.EnableSwap=y               # Create and use swapfile on resource d$
ResourceDisk.SwapSizeMB=2048            # Size of the swapfile.

ख। निम्नलिखित को रूट के रूप में करें, जिसमें आपकी मशीन को रिबूट करना शामिल है:

umount /mnt
service walinuxagent restart
reboot

सी। बूट करने के बाद भी स्वैप में सक्षम होने से पहले कुछ समय लगेगा। आप इसके साथ जांच कर सकते हैं swapon -s


1

मेरा मानना ​​है कि ऐसा करने का सही तरीका यह है कि क्लाउड-इनिट और वेगेंट प्ले 'अच्छा' दोनों एक साथ ( क्लाउड-इनिट एज़्योर डॉक्स से ) इन मानों को इस पर सेट रखना है

# disabling provisioning turns off all 'Provisioning.*' function
Provisioning.Enabled=n
# this is currently not handled by cloud-init, so let walinuxagent do it.
ResourceDisk.Format=y
ResourceDisk.MountPoint=/mnt

मैंने माउंटपॉइंट बदलने की कोशिश की, लेकिन यह ठीक से काम नहीं करता था इसलिए डॉक्स शायद मूल्यों के बारे में सटीक हैं

और फिर आप जैसे चाहें स्वैप विकल्पों को अनुकूलित कर सकते हैं

# Create and use swapfile on resource disk.
ResourceDisk.EnableSwap=y

# Size of the swapfile.
ResourceDisk.SwapSizeMB=8192

एक बुनियादी पुनरारंभ नया स्वैप ठीक करता है

sudo service walinuxagent restart

free -m
             total       used       free     shared    buffers     cached
Mem:          3944        882       3061         44         29        163
-/+ buffers/cache:        689       3255
Swap:         8192          0       8192

0

मैंने इस पर कुछ पोस्ट पढ़ी हैं, लेकिन मैं सही दृष्टिकोण के बारे में अभी भी अनिश्चित हूं, यह मानते हुए: 1. मेरे पास एक डिफ़ॉल्ट Ubuntu 14.04 LTS VM है जो अज़ूर द्वारा बनाया और चल रहा है, जो स्वैप के साथ नहीं आता है। 2. मैं अतिरिक्त स्टोरेज का उपयोग करके एक नया डिस्क बनाने के बजाय, मौजूदा VM संग्रहण का उपयोग करके एक स्वैप बनाना चाहते हैं

मुझे इसकी आवश्यकता भी थी (वास्तव में 14.04 के बजाय 16.04, लेकिन मेरा जवाब मेरे विचार से दोनों पर लागू होगा)।

पोस्ट मैंने पढ़ा है:

लेकिन जब मैंने देखा कि मुझे इतने लंबे निबंध पढ़ने हैं जो आप बताते हैं, मैं हार मानने वाला था ... लेकिन अचानक मुझे DigitalOcean के ब्लॉग में एक बहुत ही सीधा लेख याद आया:

Ubuntu 14.04 पर स्वैप कैसे जोड़ें

यह इतना सरल है कि मैंने इसके लिए एक स्क्रिप्ट भी लिखी है (कम से कम सबसे अच्छे हिस्से के लिए, अभी तक स्वप्निल सेटिंग्स और अन्य उन्नत सामग्री नहीं):

#!/usr/bin/env fsharpi

open System
open System.IO
open System.Net
open System.Diagnostics

#load "InfraTools.fs"
open Gatecoin.Infrastructure

// automation of https://www.digitalocean.com/community/tutorials/how-to-add-swap-on-ubuntu-14-04

let NUMBER_OF_GB_FOR_SWAP = 1

let isThereSwapMemoryInTheSystem (): bool =
    let _,output,_ = Tools.SafeHiddenExec("swapon", "-s")
    (output.Trim().Length > 0)

if (isThereSwapMemoryInTheSystem()) then
    Console.WriteLine("Swap already setup")
    Environment.Exit(0)

let swapFile = new FileInfo(Path.Combine("/", "swapfile"))
if not (swapFile.Exists) then
    Tools.BailIfNotSudoer("Need to use 'fallocate' to create swap file")
    Console.WriteLine("Creating swap file...")
    Tools.SafeExec("fallocate", String.Format("-l {0}G {1}", NUMBER_OF_GB_FOR_SWAP, swapFile.FullName), true)

let permissionsForSwapFile = 600
if not (Tools.OctalPermissions(swapFile) = permissionsForSwapFile) then
    Tools.BailIfNotSudoer("Need to adjust permissions of the swap file")
    Tools.SafeExec("chmod", String.Format("{0} {1}", permissionsForSwapFile, swapFile.FullName), true)

Tools.BailIfNotSudoer("Enable swap memory")
Tools.SafeExec("mkswap", swapFile.FullName, true)
Tools.SafeExec("swapon", swapFile.FullName, true)
if not (isThereSwapMemoryInTheSystem()) then
    Console.WriteLine("Something went wrong while enabling the swap file")
    Environment.Exit(1)

Tools.BailIfNotSudoer("Writing into /etc/fstab")
Tools.SafeHiddenExecBashCommand(String.Format("echo \"{0}   none    swap    sw    0   0\" >> /etc/fstab", swapFile.FullName))

ऊपर काम करने के लिए, आपको sudo apt install fsharpपहले (कम से कम Ubuntu 16.04 रिपॉजिटरी में fsharp की आवश्यकता है, निश्चित रूप से 23.04 के बारे में निश्चित नहीं है)।

इसके अलावा आपको इस InfraTools.fsफ़ाइल की आवश्यकता है :

open System
open System.IO
open System.Net

namespace Gatecoin.Infrastructure

module Tools =

    let HiddenExec (command: string, arguments: string) =
        let startInfo = new System.Diagnostics.ProcessStartInfo(command)
        startInfo.Arguments <- arguments
        startInfo.UseShellExecute <- false

        // equivalent to `>/dev/null 2>&1` in unix
        startInfo.RedirectStandardError <- true
        startInfo.RedirectStandardOutput <- true

        use proc = System.Diagnostics.Process.Start(startInfo)
        proc.WaitForExit()
        (proc.ExitCode,proc.StandardOutput.ReadToEnd(),proc.StandardError.ReadToEnd())

    let HiddenExecBashCommand (commandWithArguments: string) =
        let args = String.Format("-c \"{0}\"", commandWithArguments.Replace("\"", "\\\""))
        HiddenExec("bash", args)

    let SafeHiddenExecBashCommand (commandWithArguments: string) =
        let exitCode,stdOut,stdErr = HiddenExecBashCommand commandWithArguments
        if not (exitCode = 0) then
            Console.Error.WriteLine(stdErr)
            Console.Error.WriteLine()
            Console.Error.WriteLine("Bash command '{0}' failed with exit code {1}.", commandWithArguments, exitCode.ToString())
            Environment.Exit(1)
        exitCode,stdOut,stdErr

    let Exec (command: string, arguments: string, echo: bool) =
        let psi = new System.Diagnostics.ProcessStartInfo(command)
        psi.Arguments <- arguments
        psi.UseShellExecute <- false
        if (echo) then
            Console.WriteLine("{0} {1}", command, arguments)
        let p = System.Diagnostics.Process.Start(psi)
        p.WaitForExit()
        p.ExitCode

    let ExecBashCommand (commandWithArguments: string, echo: bool) =
        let args = String.Format("-c \"{0}\"", commandWithArguments.Replace("\"", "\\\""))
        if (echo) then
            Console.WriteLine(commandWithArguments)
        Exec("bash", args, false)

    let SafeHiddenExec (command: string, arguments: string) =
        let exitCode,stdOut,stdErr = HiddenExec(command, arguments)
        if not (exitCode = 0) then
            Console.Error.WriteLine(stdErr)
            Console.Error.WriteLine()
            Console.Error.WriteLine("Command '{0}' failed with exit code {1}. Arguments supplied: '{2}'", command, exitCode.ToString(), arguments)
            Environment.Exit(1)
        exitCode,stdOut,stdErr

    let SafeExec (command: string, arguments: string, echo: bool) =
        let exitCode = Exec(command, arguments, echo)
        if not (exitCode = 0) then
            Console.Error.WriteLine("Command '{0}' failed with exit code {1}. Arguments supplied: '{2}'", command, exitCode.ToString(), arguments)
            Environment.Exit(1)
            failwith "unreached"
        ()

    let SafeExecBashCommand (commandWithArguments: string, echo: bool) =
        let args = String.Format("-c \"{0}\"", commandWithArguments.Replace("\"", "\\\""))
        if (echo) then
            Console.WriteLine(commandWithArguments)
        SafeExec("bash", args, false)

    let FirstElementOf3Tuple (a, _, _) = a
    let SecondElementOf3Tuple (_, b, _) = b

    let SimpleStringSplit (str: string, separator: string): string list =
        List.ofSeq(str.Split([|separator|], StringSplitOptions.RemoveEmptyEntries))

    let SplitStringInLines (str: string): string list =
        SimpleStringSplit(str,Environment.NewLine)

    let CommandWorksInShell (command: string): bool =
        let exitCode =
            try
                Some(FirstElementOf3Tuple(HiddenExec(command,String.Empty))
            with
                | :? System.ComponentModel.Win32Exception -> (); None
        if exitCode.IsNone then
            false
        else
            true

    let BailIfNotSudoer(reason: string): unit =   
        if not (CommandWorksInShell "id") then
            Console.WriteLine ("'id' unix command is needed for this script to work")
            Environment.Exit(2)
            ()

        let _,idOutput,_ = HiddenExec("id","-u")
        if not (idOutput.Trim() = "0") then
            Console.Error.WriteLine ("Error: needs sudo privilege. Reason: {0}", reason)
            Environment.Exit(3)
            ()
        ()

    let OctalPermissions (file: FileInfo): int =
        let output = SecondElementOf3Tuple(SafeHiddenExec("stat", String.Format("-c \"%a\" {0}", file.FullName)))
        Int32.Parse(output.Trim())

कई समाधानों पर चर्चा की गई थी, लेकिन मुझे ऐसा नहीं लगता है जो सर्वर रिबूट में बना रहे

सर्वर रिबूट के माध्यम से मेरा जवाब देने वाला हिस्सा लेखन / / fstab फ़ाइल के लिए लेखन है।

इस समाधान के बारे में अच्छी बात यह है कि यह Azure, DigitalOcean, YouNameIt, में काम करना चाहिए ...

का आनंद लें!


2
"यह बहुत सरल है" कोड की 50 लाइनों के बाद एक ऑक्सीमोरोन का एक सा लगता है!
kqw

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.