সেই কমান্ডের জন্য সাহায্য এবং বিকল্পগুলির তালিকা দেখতে যেকোন happy-* কমান্ডের সাথে -h পতাকা ব্যবহার করুন।
স্টেট ফাইল
হ্যাপি স্টোর এবং সাবধানে একটি একক রেকর্ড সহ একটি JSON ফাইলে এর টপোলজি অবস্থা বজায় রাখে। এই স্টেট ফাইলটি ব্যবহার করে, হ্যাপি একটি টপোলজি তৈরি বা সরানোর জন্য উপযুক্ত কমান্ড চালাতে পারে।
ডিফল্ট স্টেট ফাইলটি ~/.happy_state.json এ অবস্থিত। ডিফল্ট রাষ্ট্রের নাম happy , যেমন happy-state আউটপুটে দেখা যায়:
happy-stateState Name: happy
সমান্তরাল রাষ্ট্র
হ্যাপি একাধিক সহাবস্থানের সমান্তরাল অবস্থাকে সমর্থন করে। বর্তমান অবস্থা HAPPY_STATE_ID এনভায়রনমেন্ট ভেরিয়েবল দ্বারা নির্দেশিত। যদি HAPPY_STATE_ID পরিবেশে বিদ্যমান না থাকে, happy ডিফল্ট রাষ্ট্র মান ব্যবহার করা হয়।
হ্যাপি ইনস্টলেশনের সময় HAPPY_STATE_ID তৈরি করা হয় না। অবিলম্বে অন্য সুখী রাজ্যে স্যুইচ করতে state ছাড়া অন্য একটি মান দিয়ে একটি তৈরি করুন।
export HAPPY_STATE_ID="sunny"
এখন happy-state ফলাফলগুলি একটি ভিন্ন অবস্থায় পরীক্ষা করা হচ্ছে:
happy-stateState Name: sunny
প্রতিটি রাজ্যের নিজস্ব ~/.${HAPPY_STATE_ID}_state.json ফাইলে রক্ষণাবেক্ষণ করা হয়। রাজ্যগুলির মধ্যে স্যুইচ করতে, export HAPPY_STATE_ID=" <state-name> " কমান্ডটি আবার চালান৷
সমান্তরাল অবস্থার সাথে আনইনস্টল করুন
আপনি যদি সমান্তরাল হ্যাপি স্টেট ব্যবহার করেন এবং আপনি হ্যাপি আনইনস্টল করতে চান, তাহলে প্রতিটি স্টেট সক্রিয় থাকার সাথে happy-state-delete চালানো নিশ্চিত করুন। এটি নিশ্চিত করে যে হ্যাপি দ্বারা তৈরি সমস্ত নেটওয়ার্ক নেমস্পেসগুলি লিনাক্স হোস্ট নেটওয়ার্ক কনফিগারেশনকে প্রভাবিত না করেই আপনার সিস্টেম থেকে সরানো হয়েছে।
উদাহরণস্বরূপ, happy এবং sunny দুটি অবস্থার সাথে:
export HAPPY_STATE_ID="sunny"happy-state-deleteexport HAPPY_STATE_ID="happy"happy-state-delete
প্রয়োজন অনুসারে প্রতিটি সমান্তরাল স্টেট ফাইল ম্যানুয়ালি মুছে ফেলুন:
rm -f ~/.sunny_state.jsonrm -f ~/.sunny_state.json.lockrm -f ~/.happy_state.jsonrm -f ~/.happy_state.json.lock
লগ
হ্যাপি ডিফল্টরূপে syslog লগ পাঠায়। একটি দ্বিতীয় লগ ব্যাকআপ পাঠানো হয় /tmp/${HAPPY_STATE_ID}_debug_log.txt এ।
শুভ লগগুলি দেখতে, একটি পৃথক টার্মিনাল উইন্ডোতে happy-state -l চালান। আপনি যখন হ্যাপি কমান্ড প্রবেশ করেন, লগগুলি পটভূমিতে শেল কমান্ড হ্যাপি সমস্যাগুলি দেখায়। আপনি যদি লিনাক্স নেটওয়ার্ক নেমস্পেসগুলিতে আগ্রহী হন তবে হ্যাপি কীভাবে কাজ করে তা বোঝার এটি একটি ভাল উপায়।
উদাহরণস্বরূপ, happy-node-add node00 একটি শুভ নোড তৈরি করে। এই কমান্ডের জন্য লগ আউটপুট হল:
DEBUG [HappyHost:_namespaceExists():56] Happy: namespace happy000 does not exist DEBUG [Driver:writeState():365] Happy: writing Happy state to file DEBUG [Driver:CallCmd():416] Happy [happy]: > sudo ip netns add happy000 DEBUG [HappyHost:_namespaceExists():56] Happy: namespace happy000 exists DEBUG [Driver:CallCmd():416] Happy [happy]: > sudo ip netns exec happy000 ifconfig lo up
সমস্ত Driver:CallCmd() লাইন হল শেল কমান্ড যা হ্যাপি কল করে। লগের প্রতিটি লাইন বিবেচনা করুন:
# Check to see if the target namespace (happy000) exists DEBUG [HappyHost:_namespaceExists():56] Happy: namespace happy000 does not exist # Write the link between node00 and happy000 in ~/.happy_state.json DEBUG [Driver:writeState():365] Happy: writing Happy state to file # Create the network namespace for the node DEBUG [Driver:CallCmd():416] Happy [happy]: > sudo ip netns add happy000 # Check to see if the target namespace (happy000) exists DEBUG [HappyHost:_namespaceExists():56] Happy: namespace happy000 exists # Bring up the loopback interface within the happy000 namespace DEBUG [Driver:CallCmd():416] Happy [happy]: > sudo ip netns exec happy000 ifconfig lo up
নমুনা টপোলজি
পরীক্ষার জন্য হ্যাপি এবং ওপেনওয়েভ রিপোজিটরিতে নমুনা টপোলজি অন্তর্ভুক্ত করা হয়েছে। জটিল টপোলজি নির্মাণের কমান্ড শিখতেও এগুলি ব্যবহার করুন।
- শুভ:
/topologies - OpenWeave:
/src/test-apps/happy/topologies/standalone
টপোলজি JSON এবং Shell Script ফরম্যাটে আছে।
JSON
JSON টপোলজি ফাইল happy-state-load বা weave-state-load কমান্ড ব্যবহার করে লোড করা হয়। যদি টপোলজিতে Weave অন্তর্ভুক্ত থাকে, তাহলে আপনাকে টপোলজি লোড করতে weave-state-load ব্যবহার করতে হবে, অন্যথায় Weave-নির্দিষ্ট কমান্ডগুলি এড়িয়ে যাবে।
উদাহরণস্বরূপ, ওয়েভ ছাড়া একটি টপোলজি:
happy-state-load thread_wifi_ap_internet.json
ওয়েভ সহ একটি টপোলজি:
weave-state-load three_nodes_on_thread_weave.json
আপনার বর্তমান টপোলজিকে পরবর্তীতে ব্যবহারের জন্য আলাদা JSON ফাইল হিসেবে সংরক্ষণ করতে (উদাহরণস্বরূপ, একটি টেস্ট কেস স্ক্রিপ্ট ), happy-shell -s ব্যবহার করুন :
happy-shell -s my_topology.json
এটি $HOME ডিরেক্টরিতে টপোলজি স্টেট ফাইল সংরক্ষণ করে।
শেল স্ক্রিপ্ট
শেল স্ক্রিপ্ট টপোলজি ফাইলগুলি সংশ্লিষ্ট JSON ফাইলগুলিতে টপোলজি তৈরি করতে হ্যাপি এবং ওয়েভ কমান্ডের সেট ধারণ করে। ডিফল্টরূপে এই স্ক্রিপ্টগুলির এক্সিকিউটেবল অনুমতি নেই। এগুলি দুটি উপায়ে চালানো যেতে পারে:
bash কমান্ড ব্যবহার করে:
bash thread_wifi_ap_internet.sh
এক্সিকিউটেবল অনুমতি প্রয়োগ করে:
chmod +x thread_wifi_ap_internet.sh./thread_wifi_ap_internet.sh
কনফিগারেশন
হ্যাপির তিনটি কনফিগারেশন ফাইল রয়েছে:
| কনফিগারেশন ফাইল | বর্ণনা |
|---|---|
~/.happy_conf.json | ব্যক্তিগত বা প্লাগ-ইন ব্যবহারের জন্য কনফিগারেশন ভেরিয়েবল। happy-configuration কমান্ড ব্যবহার করে এই মানগুলি সেট করুন। |
<path-to-happy> /happy/conf/main_config.json | প্রাইমারি হ্যাপি কনফিগারেশন ভেরিয়েবল। |
<path-to-happy> /happy/conf/log_config.json | লগ কনফিগারেশন। |
কনফিগারেশন ভেরিয়েবল যোগ করুন
আমরা আপনাকে happy-configuration কমান্ড ব্যবহার করার পরামর্শ দিই যে ডিফল্টের বাইরে যেকোন ব্যক্তিগত বা প্লাগ-ইন ভেরিয়েবল সেট করতে যা আপনার হ্যাপির নির্দিষ্ট স্থাপনার প্রয়োজন।
উদাহরণস্বরূপ, টেস্ট স্ক্রিপ্টের জন্য Weave test-apps ডিরেক্টরি কোথায় পাওয়া যাবে তা হ্যাপিকে জানাতে, weave_path ভেরিয়েবল সেট করুন:
happy-configuration weave_path <path-to-openweave-core>/build/x86_64-unknown-linux-gnu/src/test-apps
~/.happy_conf.json এ হ্যাপি স্টোরের কনফিগারেশন ভেরিয়েবল।
নোড প্রক্রিয়া
হ্যাপি সিমুলেটেড নোডের মধ্যে প্রসেস শুরু এবং বন্ধ করার জন্য কমান্ড প্রদান করে।
একটি প্রক্রিয়া শুরু করতে:
happy-process-start <node-name> <custom-process-name> <command>
উদাহরণস্বরূপ, ThreadNode নামে একটি নোডে ক্রমাগত একটি পিং চালানোর জন্য:
happy-process-start ThreadNode ContinuousPing ping 8.8.8.8
উপরের উদাহরণে, ContinuousPing হল প্রক্রিয়াটির ব্যবহারকারী-নির্ধারিত নাম যা হ্যাপি প্রক্রিয়া পরিচালনা করতে ব্যবহার করে। প্রসেস এক্সিকিউশন স্থগিত করার জন্য happy-process-wait ব্যবহার করুন এবং প্রক্রিয়াটিকে মেরে ফেলতে happy-process-stop ব্যবহার করুন।
প্রসেস আউটপুট /tmp এ রয়েছে। উদাহরণস্বরূপ, ContinuousPing প্রক্রিয়া শুরু করার পরে, /tmp ডিরেক্টরিটি পরীক্ষা করুন:
ls /tmp/happy*/tmp/happy_018691_1524087014.192197_ContinuousPing.out
এই .out ফাইলটিতে ContinuousPing প্রক্রিয়ার আউটপুট রয়েছে।
sudo ব্যবহার
হ্যাপি নেটওয়ার্ক কনফিগারেশন পরিবর্তন করে যা লিনাক্স কার্নেল দ্বারা নিয়ন্ত্রিত হয়। যেহেতু শুধুমাত্র root কার্নেল কনফিগারেশন পরিবর্তন করতে পারে, হ্যাপি আপনাকে অপারেশন চলাকালীন sudo পাসওয়ার্ড লিখতে অনুরোধ করে।
হ্যাপি sudo কল করতে $SUDO সিস্টেম এনভায়রনমেন্ট ভেরিয়েবল ব্যবহার করে। $SUDO সংজ্ঞায়িত না হলে, হ্যাপি একটি সাধারণ sudo কল করে।
পাইথন স্ক্রিপ্টিং
ইনস্টলেশনের পরে, নিম্নলিখিত import বিবৃতি ব্যবহার করে হ্যাপি পাইথন প্যাকেজগুলি একটি পাইথন পরিবেশে আমদানি করা যেতে পারে:
import happy
/happy পাওয়া স্বতন্ত্র কমান্ড মডিউলগুলি নিম্নরূপ আমদানি করা হয়েছে:
import happy.HappyNodeAdd
মডিউল বিকল্পগুলি পুনরুদ্ধার করতে, option() ফাংশনটি কল করুন। উদাহরণস্বরূপ, HappyNodeAdd মডিউল বিকল্পগুলি পুনরুদ্ধার করতে:
module options import happy.HappyNodeAdd options = happy.HappyNodeAdd.option()