Tags:
Node Thumbnail

ออราเคิลแจ้งเตือนว่า macOS 14.4 รุ่นล่าสุดทำให้แอปจาวาจำนวนหนึ่งมีปัญหาบางกรณีจนทำให้แอปแครช หากองค์กรใดใช้แอปจาวาอยู่ให้ระวังการใช้งาน

ปัญหาเรื่องนี้เกิดจากแอปจาวานั้นอาจจะมีบางครั้งที่ไปพยายามเข้าถึงหน่วยความจำส่วนที่ห้ามใช้งานอยู่ เดิม macOS จะส่ง SIGBUS หรือ SIGSEGV ออกมา และแอปพลิเคชั่นสามารถรับ signal นี้และทำงานต่อไปได้ แต่ใน macOS 14.4 แอปเปิลกลับเปลี่ยนเป็น SIGKILL ที่ตัวโปรเซสทำอะไรไม่ได้

ออราเคิลระบุว่าไม่พบปัญหานี้ในเวอร์ชั่น early access ของ macOS 14.4 ทำให้ไม่สามารถแจ้งปัญหาให้แอปเปิลล่วงหน้า และตอนนี้ต้องรอแอปเปิลแก้บั๊ก โดยกระทบตั้งแต่แอป Java 8 จนถึงรุ่นล่าสุด

ที่มา - Oracle

Get latest news from Blognone

Comments

By: PH41
ContributorAndroidUbuntuWindows
on 18 March 2024 - 00:47 #1308102
PH41's picture

อ่านข่าวแล้วคิดว่าเป็นบัคของ Java เองมากกว่า

By: lew
FounderJusci's WriterMEconomicsAndroid
on 18 March 2024 - 05:59 #1308106 Reply to:1308102
lew's picture

คนทำ kernel นี่ถ้าพฤติกรรมเปลี่ยนจนแอปพัง ปกติแทบทุกคนถือว่าเป็นบั๊กของตัวเองหมดครับ windows นี่มี caveat เยอะมากเพราะรองรับความประหลาดของแอปแทบทุกตัวที่เคยรันบนวินโดวส์

ลินุกซ์นี่เจอปัญหานี้ตลอดมา แทบไม่กล้าเปลี่ยนพฤติกรรม Kernel API แม้บางทีจะไม่ตรงกับที่ออกแบบไว้ (ดูเพิ่มเติมการบรรยายของ Michael Kerrisk เมื่อปี 2019)


lewcpe.com, @wasonliw

By: PH41
ContributorAndroidUbuntuWindows
on 18 March 2024 - 11:09 #1308131 Reply to:1308106
PH41's picture

ขอบคุณครับ อ่าน comment ล่างแล้ว บัค OS แหละ และบัค Java ด้วย 😂

By: gamoman
AndroidWindows
on 18 March 2024 - 11:43 #1308135 Reply to:1308106

ปัญหาเรื่องนี้เกิดจากแอปจาวานั้นอาจจะมีบางครั้งที่ไปพยายามเข้าถึงหน่วยความจำส่วนที่ห้ามใช้งานอยู่ เดิม macOS จะส่ง SIGBUS หรือ SIGSEGV ออกมา และแอปพลิเคชั่นสามารถรับ signal นี้และทำงานต่อไปได้

ประโยคนี้เหมือน Java จะทำผิดแม้ระบบจะเตือนแล้ว
แต่ App ก็ยังทำงานได้ Java เลยทำผิดต่อไปจนกลายเป็นนิสัย
พอ Apple เปลี่ยนให้ระบบทำงานรัดกุมขึ้น App ใช้ไม่ได้
กลายเป็น Apple ผิดต้องแก้ไขซะงั้น

By: Ford AntiTrust
ContributorAndroidBlackberryUbuntu
on 18 March 2024 - 13:13 #1308145 Reply to:1308135
Ford AntiTrust's picture

Apple ทำผิดพฤติกรรมที่คาดหวังไว้ว่าจะส่ง SIGBUS หรือ SIGSEGV ออกมาครับ เหมือนตกลงกันไว้แล้ว แต่ OS ตัวอัพเดทแล้วส่ง SIGKILL แทน ทำให้โปรแกรมหยุดทำงานแทน ซึ่งไม่ถูกต้องตามที่ตกลงกันไว้

ส่วนว่า OS ส่ง SIGBUS หรือ SIGSEGV ออกมาเพราะเข้าถึงหน่วยความจำส่วนที่ห้ามใช้งาน ก็คือแจ้งโปรแกรม (ในชีวิตจริง มันเกิดขึ้นได้) ทีนี้ พอได้รับแจ้ง หลังจากนี้จะทำอะไรต่อก็ว่ากันไป ซึ่งในข่าวไม่ได้บอกไว้ ให้เดา อาจจะย้ายไปใช้หน่วยความจำจุดอื่นแทน หรือแก้ไขการจองหน่วยความจำอะไรก็ว่าไป ซึ่งโปรแกรมไม่ถูกสั่งให้หยุดทำงานทันที รวมไปถึงหากมัน crash ก็ยังพอเก็บ dump exception จุดต่างๆ ได้ เอาไปแก้ไขต่อใน patch ถัดไป

By: big50000
AndroidSUSEUbuntu
on 18 March 2024 - 12:45 #1308142 Reply to:1308106
big50000's picture

We do not break userspace!

นอกเรื่องนิดหน่อย ขนาด Linux Kernel รักษา Interface ไว้ได้ดีขนาดนี้ แต่ทำไมลูกหาบ (Linux Distro) ไม่ปฏิบัติตามบ้างว้าาาาาาา

By: nanana
Windows PhoneAndroidUbuntu
on 18 March 2024 - 02:55 #1308105

SIGKILL:
เป็นสัญญาณที่ไม่สามารถถูกดักจับ (intercept) หรือละเว้น (ignore) ได้
โปรแกรมจะถูกบังคับให้หยุดทำงานทันที โดยไม่ต้องทำความสะอาด (cleanup) ใดๆ
มักใช้ในกรณีที่โปรแกรมหยุดทำงานหรือทำงานผิดพลาดอย่างร้ายแรง

SIGBUS:
เป็นสัญญาณที่เกิดขึ้นเมื่อโปรแกรมพยายามเข้าถึงหน่วยความจำที่ไม่ถูกต้อง
โปรแกรมสามารถดักจับสัญญาณนี้และจัดการกับมันได้
มักใช้เพื่อแจ้งเตือนโปรแกรมเกี่ยวกับข้อผิดพลาดในการเข้าถึงหน่วยความจำ

By: btoy
ContributorAndroidWindows
on 18 March 2024 - 13:11 #1308144
btoy's picture

เข้ามาเก็บความรู้ :)


..: เรื่อยไป

By: EngineerRiddick
iPhoneWindows PhoneAndroidUbuntu
on 18 March 2024 - 13:51 #1308149
EngineerRiddick's picture

วิชา OS Architecture 101 ╰(´︶`)╯♡
บทนี้ SIGKILL, SIGBUS บทถัดไป memory address&overflow นศ.เตรียมสำหรับ ชม.หน้าด้วยนะครัส:)

By: Iamz
AndroidWindows
on 20 March 2024 - 18:32 #1308347

เดาว่าตามสไตล์ของ Apple อย่างมากก็แก้กลับให้พฤติกรรมเป็นเหมือนเดิมโดยไม่อธิบายเหตุผล ว่ามีความจำเป็นอะไรรึเปล่าถึงจำเป็นจะต้องเปลี่ยนพฤติกรรมให้ต่างจากตัว early access. ตามปกติแล้วจาก early access ถึงตัวจริงควรจะแก้แค่ปัญหาที่พบจาก early access เท่าที่จำเป็น ไม่แก้อย่างอื่นจะได้ไม่เจอปัญหาแบบนี้