Unix UID มีขนาดใหญ่เท่าใด


18

ฉันเข้าใจว่า ID ผู้ใช้ unix (UID) มักเป็นจำนวนเต็ม 16 หรือ 32 บิตที่ไม่มีเครื่องหมาย แต่ฉันจะหาระบบที่กำหนด (ในเชลล์) ได้อย่างไร

คำตอบ:


12

คุณจะต้องมองใน<limits.h>(หรือหนึ่งของไฟล์ที่จะมีเช่นsys/syslimits.hบน OS X) สำหรับของ#defineUID_MAX

ระบบปฏิบัติการล่าสุด (Solaris 2.x, OS X, BSD, Linux, HP-UX 11i, AIX 6) สามารถรองรับได้ถึงสองพันล้าน ( 2^31-2) ดังนั้นฉันจะสมมติและแก้ปัญหาสำหรับระบบที่คลุมเครือมากกว่า 'T


1
UID_MAXแต่น่าเสียดายที่ไม่มีสิ่งเช่น ตัวอย่างเช่นเครื่องมือจากการshadow-utilsใช้(uid_t)-1เพื่อค้นหาค่าสูงสุดสำหรับ UID
kirelagin

5
ระบบส่วนใหญ่ใช้ /etc/login.defs ซึ่งมีการตั้งค่า UID_MAX สำหรับค่า UID ที่ใช้งานได้สูงสุด 60000 ในระบบใดก็ตามที่ฉันตรวจสอบ
Ryaner

6
manpageสำหรับlogin.defsแสดงให้เห็นว่าในบริบทที่UID_MAXเพียงควบคุม UID สูงสุดที่จะได้รับมอบหมายโดยอัตโนมัติสำหรับผู้ใช้ใหม่ที่สร้างขึ้นด้วยuseraddสูงสุดที่จะได้รับมอบหมายโดยอัตโนมัติสำหรับผู้ใช้ใหม่ที่สร้างขึ้นด้วย
Stephen Touset

2
อาจเป็น 2 ^ 32 (4 พันล้านแทนที่จะเป็น 2) บน RHEL UID 4,294,967,295 (2 ^ 32-1) มักจะสงวนไว้สำหรับ UID "ค่าไม่ถูกต้อง" และ 4,294,967,294 (2 ^ 32-2) จะถูกสงวนไว้สำหรับผู้ใช้ nfsnobody ในระบบปฏิบัติการบางระบบ ดังนั้นค่าที่ไม่ได้จองไว้สูงสุดคือ 4,294,967,293 (2 ^ 32-3)
tehnicaorg

4

glibc ให้คำจำกัดความสำหรับประเภทระบบทั้งหมดเหล่านั้น

คุณสามารถตรวจสอบ/usr/include/bits/typesizes.h:

% grep UID_T /usr/include/bits/typesizes.h
#define __UID_T_TYPE            __U32_TYPE

ถัดไปที่คุณมองเข้าไป/usr/include/bits/types.h:

% grep '#define __U32_TYPE' /usr/include/bits/types.h
#define __U32_TYPE              unsigned int

สิ่งนี้ช่วยให้คุณค้นหาประเภท C เนื่องจากคุณต้องการขนาดเป็นไบต์ตัวเลือกที่ดีที่สุดของคุณคือการแยกชื่อ typedef ตามข้อกำหนดในtypes.h:

We define __S<SIZE>_TYPE and __U<SIZE>_TYPE for the signed and unsigned
variants of each of the following integer types on this machine.

 16      -- "natural" 16-bit type (always short)
 32      -- "natural" 32-bit type (always int)
 64      -- "natural" 64-bit type (long or long long)
 LONG32      -- 32-bit type, traditionally long
 QUAD        -- 64-bit type, always long long
 WORD        -- natural type of __WORDSIZE bits (int or long)
 LONGWORD    -- type of __WORDSIZE bits, traditionally long

ดังนั้นนี่คือหนึ่งซับ:

% grep '#define __UID_T_TYPE' /usr/include/bits/typesizes.h | cut -f 3 | sed -r 's/__([US])([^_]*)_.*/\1 \2/'
U 32

ที่นี่Uหมายถึงunsigned(สิ่งนี้สามารถSสำหรับsigned) และ32เป็นขนาด (ค้นหาในรายการข้างต้นฉันคิดว่าเวลาส่วนใหญ่คุณสามารถคิดว่ามันมีขนาดเป็นไบต์แล้ว แต่ถ้าคุณต้องการให้สคริปต์ของคุณพกพาได้เต็มที่ อาจดีกว่าที่จะcaseเปลี่ยนค่านี้)


1
ในระบบของฉัน (Ubuntu 12.04) และระบบที่ใช้เดเบียนอื่น ๆ ไฟล์ส่วนหัวคือ: /usr/include/$(gcc -print-multiarch)/bits/typesizes.hหรืออีกทางหนึ่ง:/usr/include/$(dpkg-architecture -qDEB_HOST_MULTIARCH)/bits/typesizes.h
pabouk

1
การมีไฟล์ glibc เหล่านั้นอาจหมายความว่ามีคอมไพเลอร์อยู่ ดังนั้นเราสามารถ#include <sys / types.h>มีสิทธิ์เข้าถึงuid_tและพิมพ์ผลลัพธ์ ( printf ("uid_t:% d ไบต์ (% d บิต) \ n", sizeof (uid_t), sizeof (uid_t) * 8 ); )
tehnicaorg

3

นั่นเป็นคำถามที่น่าสนใจ ฉันจะแปลกใจถ้ามีวิธีมาตรฐานแบบพกพาในการตรวจสอบนี้

ฉันไม่มีกล่อง Linux มีประโยชน์ แต่ idคำสั่งใน FreeBSD 8.0 ล้อมกลับเป็นศูนย์:

# id 4294967296
uid=0(root) gid=0(wheel) groups=0(wheel),5(operator)

ฉันแน่ใจว่านี่เป็นพฤติกรรมที่ไม่ได้กำหนด แต่ฉันจะเดิมพันว่าเวอร์ชันส่วนใหญ่idจะรวมเป็นศูนย์ด้วย65'536(ถ้า UID แบบ 16 บิต) และ4'294'967'296หรือเกิดข้อผิดพลาดหากคุณใช้เกินขีด จำกัด ของระบบ


3

ในลิงก์นี้คำถามจะถูกถามและผู้ตอบกลับจะใช้วิธีการลองผิดลองถูกเพื่อตรวจสอบว่าระบบนั้นใช้ long long ที่ได้รับการลงนามแล้วปล่อยให้บิต 31 บิตเก็บค่าไว้ได้สูงสุด 2,147,483,647

# groupadd -g 42949672950 testgrp
# more /etc/group
testgrp:*:2147483647:
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.