আমি মেশিনে ssh'ing পরে দূরবর্তীভাবে ম্যাক ওএস এক্স 10.5 এ নতুন ব্যবহারকারী তৈরি করতে সক্ষম হতে চাই। আমি এটা কিভাবে করবো?
আমি মেশিনে ssh'ing পরে দূরবর্তীভাবে ম্যাক ওএস এক্স 10.5 এ নতুন ব্যবহারকারী তৈরি করতে সক্ষম হতে চাই। আমি এটা কিভাবে করবো?
উত্তর:
Dscl কমান্ড ব্যবহার করুন। এই উদাহরণটি ব্যবহারকারীকে "লুসার" তৈরি করবে, যেমন:
dscl . -create /Users/luser
dscl . -create /Users/luser UserShell /bin/bash
dscl . -create /Users/luser RealName "Lucius Q. User"
dscl . -create /Users/luser UniqueID "1010"
dscl . -create /Users/luser PrimaryGroupID 80
dscl . -create /Users/luser NFSHomeDirectory /Users/luser
তারপরে আপনি ব্যবহারকারীর পাসওয়ার্ড পরিবর্তন করতে পাসডওইডি ব্যবহার করতে পারেন বা ব্যবহার করতে পারেন:
dscl . -passwd /Users/luser password
আপনাকে ব্যবহারকারীর হোম ডিরেক্টরিতে / ব্যবহারকারী / লুজার তৈরি করতে হবে এবং মালিকানা পরিবর্তন করতে হবে যাতে ব্যবহারকারী এটি অ্যাক্সেস করতে পারে এবং নিশ্চিত হন যে ইউনিকআইডি আসলেই অনন্য।
এই লাইনটি প্রশাসকের গোষ্ঠীতে ব্যবহারকারীকে যুক্ত করবে:
dscl . -append /Groups/admin GroupMembership luser
useradd
সিনট্যাক্সে পোর্ট করেছি ।
PrimaryGroupID 80
হয় admin
, তাই luser
ব্যবহার করতে পারেন sudo
যদি আপনি তাকে অ্যাডমিনিস্ট্রেটররা এর গ্রুপে যুক্ত এমনকি।
(এই উত্তরটি পামারের পদ্ধতিতে কিছু ফাঁকা স্থান পূরণ করার জন্য একটি সংযোজন হিসাবে বিবেচনা করা উচিত)
আপনার নতুন ব্যবহারকারীর জন্য অব্যবহৃত ইউনিকআইডি বাছাই করতে আপনি ব্যবহার করতে পারেন:
maxid=$(dscl . -list /Users UniqueID | awk 'BEGIN { max = 500; } { if ($2 > max) max = $2; } END { print max + 1; }')
newid=$((maxid+1))
... তারপরে অ্যাকাউন্ট তৈরি করতে পামার প্রদত্ত dscl কমান্ডগুলির ক্রম ব্যবহার করুন এবং তারপরে নতুন ব্যবহারকারীর হোম ডিরেক্টরিটি তৈরি করুন:
cp -R /System/Library/User\ Template/English.lproj /Users/luser
chown -R luser:staff /Users/luser
if [[ "$(sw_vers -productVersion)" != 10.[0-5].* ]]; then
# Set ACL on Drop Box in 10.6 and later
chmod +a "user:luser allow list,add_file,search,delete,add_subdirectory,delete_child,readattr,writeattr,readextattr,writeextattr,readsecurity,writesecurity,chown,file_inherit,directory_inherit" /Users/luser/Public/Drop\ Box
fi
(একটি ক্রিয়েমোডির কমান্ড রয়েছে, তবে আমি এটি পরীক্ষার সময় কার্যকর হয়নি))
sudo createhomedir -s
তোলে এবং তারপরে ওপেন ডিরেক্টরি রেপ্লিকা / ফাইলসারে কল করুন (আইআইআরসি), এবং তারা আনন্দের সাথে হোম ডিরেক্টরিগুলি তৈরি করে create
dscl -list
256 ফলাফলের মধ্যে সীমাবদ্ধ, সুতরাং আপনার 256 টির বেশি ব্যবহারকারী থাকলে এই কৌশলটি একটি অনন্য ইউআইডি গ্যারান্টি দিতে ব্যর্থ হবে।
আপনার যদি তৈরি করার মতো গুচ্ছ ব্যবহারকারী থাকে তবে একটি কাঠামোগত পাঠ্য ফাইল তৈরি করা এবং কাজটি করার dsimport
জন্য এটি পাস করা সম্ভব ।
অ্যাপলের কমান্ড-লাইন অ্যাডমিনিস্ট্রেশন গাইডের ব্যবহারকারী এবং গোষ্ঠী সম্পর্কে পুরো অধ্যায় রয়েছে।
অ্যাকাউন্ট তৈরি করার আগে একটি অনন্য ইউজার আইডি বাছাই বাছাই করার অন্য একটি উপায় হ'ল তালিকার সন্ধান করা এবং আপনি যেটি ব্যবহার করতে চান তা সেখানে নেই তা যাচাই করে দেখুন:
sudo dscl . list /Users uid
sudo dscl . list groups gid
আপনি যদি একটি নির্দিষ্ট আইডি ব্যবহার করতে চান প্রয়োজন
dscl -list
256 ফলাফলের মধ্যে সীমাবদ্ধ, সুতরাং আপনার 256 টির বেশি ব্যবহারকারী থাকলে এই কৌশলটি একটি অনন্য ইউআইডি গ্যারান্টি দিতে ব্যর্থ হবে।
grep
সঙ্গে এটি id
আপনি মনের মধ্যে ছিল জন্য নতুন ব্যবহারকারী ব্যবহার করতে
আমি ব্যবহারকারী অ্যাকাউন্টগুলি তৈরি করার জন্য একটি দুর্দান্ত স্ক্রিপ্ট বলে মনে করি তার সাথে সামনে আসতে আমি এখানে বিভিন্ন উত্তরগুলি উপস্থাপন করেছি। স্বীকার করা, এটি ssh থেকে কোনও সময়ে কমান্ড চালানোর জন্য ডিজাইন করা হয়নি; ওএস এক্সের প্যাকেজ-ভিত্তিক চিত্র সংকলন করার সময় এটি স্ক্রিপ্ট রান হিসাবে ডিজাইন করা হয়েছে (যেমনটি ক্যাস্পার ইমেজিং বা ইন্সটাডিএমজি দ্বারা নির্মিত )।
#!/bin/bash
# This script creates a user account under Mac OS X
# (tested with 10.5 and 10.6; likely works with 10.4 but not earlier)
# Written by Clinton Blackmore, based on work at
# http://serverfault.com/questions/20702
# === Typically, this is all you need to edit ===
USERNAME=joeadmin
FULLNAME="Joe Admin"
PASSWORD="hard_to_hack"
# A list of (secondary) groups the user should belong to
# This makes the difference between admin and non-admin users.
# Leave only one uncommented
#SECONDARY_GROUPS="" # for a non-admin user
SECONDARY_GROUPS="admin _lpadmin _appserveradm _appserverusr" # for an admin user
# ====
if [[ $UID -ne 0 ]]; then echo "Please run $0 as root." && exit 1; fi
# Find out the next available user ID
MAXID=$(dscl . -list /Users UniqueID | awk '{print $2}' | sort -ug | tail -1)
USERID=$((MAXID+1))
# Create the user account
dscl . -create /Users/$USERNAME
dscl . -create /Users/$USERNAME UserShell /bin/bash
dscl . -create /Users/$USERNAME RealName "$FULLNAME"
dscl . -create /Users/$USERNAME UniqueID "$USERID"
dscl . -create /Users/$USERNAME PrimaryGroupID 20
dscl . -create /Users/$USERNAME NFSHomeDirectory /Users/$USERNAME
dscl . -passwd /Users/$USERNAME $PASSWORD
# Add use to any specified groups
for GROUP in $SECONDARY_GROUPS ; do
dseditgroup -o edit -t user -a $USERNAME $GROUP
done
# Create the home directory
createhomedir -c > /dev/null
echo "Created user #$USERID: $USERNAME ($FULLNAME)"
স্ক্রিপ্টটি আপনাকে নির্দিষ্ট করতে দেয় যে কোনও দলের কোন গ্রুপের অন্তর্ভুক্ত। আমার কাছে এটি প্রদর্শিত হবে যে আপনি ওএস এক্সের যে সংস্করণটি চালাচ্ছেন তার উপর নির্ভর করে এটি পৃথক হতে পারে। id
ওএস এক্স 10.5 এ অ্যাডমিন হিসাবে চালিত হওয়ার চেয়ে আমি ওএস এক্স 10.6 এ অ্যাডমিন হিসাবে চালিত হওয়ার পরে আমি আলাদা ফলাফল পেয়েছি ।
dscl -list
256 ফলাফলের মধ্যে সীমাবদ্ধ, সুতরাং আপনার 256 টির বেশি ব্যবহারকারী থাকলে এই কৌশলটি একটি অনন্য ইউআইডি গ্যারান্টি দিতে ব্যর্থ হবে।
আমি শুরু একটু মোড়কের সম্পর্কে dscl
যে সময় লাগে useradd
এর পরামিতি - এটা সম্পূর্ণ নয় (কিংবা আমার মনে হয় এটা হতে পারে যেমন কিছু জিনিস OS X এর সম্ভব নয় না), কিন্তু আমি এটা ব্যবহার কিছু ব্যবহারকারী তৈরি করতে।
সমস্ত পরামিতিগুলির জন্য ফ্রেমওয়ার্কটি রয়েছে, সুতরাং আপনি যদি গিটহাবের দুর্দান্ত ভিডিওগুলির সুবিধা নিতে চান তবে এটি করা সহজ।
single_user
মোড থেকে কীভাবে করবেন (সিকিউরিটি রিসেট) সন্ধান করছেন তবে আপনাকেCommand-S
অন-স্ক্রিনের বিশদ অনুযায়ী ডিস্কে রাইট অ্যাক্সেস অর্জন করতে হবে , এবং তারপরেrm /var/db/.AppleSetupDone
যা আপনাকে একটি নতুন প্রশাসক অ্যাকাউন্ট তৈরি করতে দেয়। আশা করি এটি কাউকে সাহায্য করবে