主頁 > 資料庫 > 如何在MASM中跨段填充塊?

如何在MASM中跨段填充塊?

2022-11-05 03:25:34 資料庫

假設我有一些這樣的代碼:

_TEXT16 SEGMENT USE16 'CODE'
_start:
    ; some code...
; add padding
byte 512-($-_start) dup (0)    ; works fine
_TEXT16 ENDS

_TEXT32 SEGMENT USE32 'CODE'
; some code
byte 1024-($-_start) dup (0)    ; error A2192: Operands must be in same segment
_TEXT32 ENDS

在 NASM 中,您只需執行類似的操作times 1024-($-$$) db 0,但不幸的$$是,MASM 或 JWASM 不支持,這是我目前正在使用的。我需要它來將引導加載程式的塊與可讀磁盤扇區的大小對齊。

所以,我的問題是,如何在 MASM 中的代碼塊中添加 512 位元組的填充?

編輯:

場景發生了一些變化。

_TEXT16 SEGMENT USE16 'CODE'
_start:
    ; some code...
_TEXT16 ENDS

_TEXT32 SEGMENT USE32 'CODE'
; some code
_TEXT32 ENDS

_TEXT64 SEGMENT USE64 'CODE'
; some code

; add padding
byte 510-($-_start) dup (0)    ; error A2192: Operands must be in same segment
dw 0AA55h
_TEXT64 ENDS

現在我將如何在這里添加正確的填充?

uj5u.com熱心網友回復:

好的,這很難解釋,但我終于解決了我的問題。
最終作業的代碼是這樣的:

.386P
.model TINY, C

_TEXT16 SEGMENT BYTE USE16 'CODE'
org 07C00h
begin16:

_start:
    xor ax, ax
    mov ds, ax
    mov es, ax
    mov ss, ax

    mov bp, 07C00h
    mov sp, bp

    mov ah, 0Eh
    mov al, 'A'
    mov bl, 0Fh
    int 10h

    cli
    hlt

end16:
size16 equ end16 - begin16
_TEXT16 ENDS

_TEXT32 SEGMENT BYTE USE32 'CODE'
begin32:

start_protected_mode:
    cli
    hlt

end32:
size32 equ end32 - begin32
_TEXT32 ENDS

.x64
_TEXT64 SEGMENT BYTE USE64 'CODE'
begin64:

start_long_mode:
    cli
    hlt

end64:
size64 equ end64 - begin64
_TEXT64 ENDS

_BOOTDATA SEGMENT BYTE 'DATA'
begin_data:

bootDisk db ?

end_data:
size_data equ end_data - begin_data
_BOOTDATA ENDS

_PADDING SEGMENT BYTE
org (510 - size16 - size32 - size64 - size_data)                ; either of these work
;byte (510 - size16 - size32 - size64 - size_data) dup(0)       ; either of these work
dw 0AA55h
_PADDING ENDS

END _start

這里發生的事情如下。第一個org指令 ( org 07C00h) 設定程式的起始地址。它這樣做只是因為我們已經使用END指令告訴它,我們已經為代碼的開頭 ( END _start) 提供了一個標簽。如果您沒有為END指令提供代碼的說明標簽,則第一個org指令將被決議為在您的實際代碼之前的許多零。或者簡而言之,它實際上會通過你給它的任何值來抵消你的代碼。
然而,第二個org指令 ( org org (510 - size16 - size32 - size64 - size_data)) 就像一個偏移量,即使你沒有給END指令一個標簽。
考慮到所有這些,我們的結果如下所示:

00000000  33C0              xor ax,ax
00000002  8ED8              mov ds,ax
00000004  8EC0              mov es,ax
00000006  8ED0              mov ss,ax
00000008  BD007C            mov bp,0x7c00
0000000B  8BE5              mov sp,bp
0000000D  B40E              mov ah,0xe
0000000F  B041              mov al,0x41
00000011  B30F              mov bl,0xf
00000013  CD10              int 0x10
00000015  FA                cli
00000016  F4                hlt
00000017  FA                cli
00000018  F4                hlt
00000019  FA                cli
0000001A  F4                hlt
0000001B  0000              add [bx si],al
0000001D  0000              add [bx si],al
0000001F  0000              add [bx si],al
00000021  0000              add [bx si],al
00000023  0000              add [bx si],al
00000025  0000              add [bx si],al
00000027  0000              add [bx si],al
00000029  0000              add [bx si],al
0000002B  0000              add [bx si],al
0000002D  0000              add [bx si],al
0000002F  0000              add [bx si],al
00000031  0000              add [bx si],al
00000033  0000              add [bx si],al
00000035  0000              add [bx si],al
00000037  0000              add [bx si],al
00000039  0000              add [bx si],al
0000003B  0000              add [bx si],al
0000003D  0000              add [bx si],al
0000003F  0000              add [bx si],al
00000041  0000              add [bx si],al
00000043  0000              add [bx si],al
00000045  0000              add [bx si],al
00000047  0000              add [bx si],al
00000049  0000              add [bx si],al
0000004B  0000              add [bx si],al
0000004D  0000              add [bx si],al
0000004F  0000              add [bx si],al
00000051  0000              add [bx si],al
00000053  0000              add [bx si],al
00000055  0000              add [bx si],al
00000057  0000              add [bx si],al
00000059  0000              add [bx si],al
0000005B  0000              add [bx si],al
0000005D  0000              add [bx si],al
0000005F  0000              add [bx si],al
00000061  0000              add [bx si],al
00000063  0000              add [bx si],al
00000065  0000              add [bx si],al
00000067  0000              add [bx si],al
00000069  0000              add [bx si],al
0000006B  0000              add [bx si],al
0000006D  0000              add [bx si],al
0000006F  0000              add [bx si],al
00000071  0000              add [bx si],al
00000073  0000              add [bx si],al
00000075  0000              add [bx si],al
00000077  0000              add [bx si],al
00000079  0000              add [bx si],al
0000007B  0000              add [bx si],al
0000007D  0000              add [bx si],al
0000007F  0000              add [bx si],al
00000081  0000              add [bx si],al
00000083  0000              add [bx si],al
00000085  0000              add [bx si],al
00000087  0000              add [bx si],al
00000089  0000              add [bx si],al
0000008B  0000              add [bx si],al
0000008D  0000              add [bx si],al
0000008F  0000              add [bx si],al
00000091  0000              add [bx si],al
00000093  0000              add [bx si],al
00000095  0000              add [bx si],al
00000097  0000              add [bx si],al
00000099  0000              add [bx si],al
0000009B  0000              add [bx si],al
0000009D  0000              add [bx si],al
0000009F  0000              add [bx si],al
000000A1  0000              add [bx si],al
000000A3  0000              add [bx si],al
000000A5  0000              add [bx si],al
000000A7  0000              add [bx si],al
000000A9  0000              add [bx si],al
000000AB  0000              add [bx si],al
000000AD  0000              add [bx si],al
000000AF  0000              add [bx si],al
000000B1  0000              add [bx si],al
000000B3  0000              add [bx si],al
000000B5  0000              add [bx si],al
000000B7  0000              add [bx si],al
000000B9  0000              add [bx si],al
000000BB  0000              add [bx si],al
000000BD  0000              add [bx si],al
000000BF  0000              add [bx si],al
000000C1  0000              add [bx si],al
000000C3  0000              add [bx si],al
000000C5  0000              add [bx si],al
000000C7  0000              add [bx si],al
000000C9  0000              add [bx si],al
000000CB  0000              add [bx si],al
000000CD  0000              add [bx si],al
000000CF  0000              add [bx si],al
000000D1  0000              add [bx si],al
000000D3  0000              add [bx si],al
000000D5  0000              add [bx si],al
000000D7  0000              add [bx si],al
000000D9  0000              add [bx si],al
000000DB  0000              add [bx si],al
000000DD  0000              add [bx si],al
000000DF  0000              add [bx si],al
000000E1  0000              add [bx si],al
000000E3  0000              add [bx si],al
000000E5  0000              add [bx si],al
000000E7  0000              add [bx si],al
000000E9  0000              add [bx si],al
000000EB  0000              add [bx si],al
000000ED  0000              add [bx si],al
000000EF  0000              add [bx si],al
000000F1  0000              add [bx si],al
000000F3  0000              add [bx si],al
000000F5  0000              add [bx si],al
000000F7  0000              add [bx si],al
000000F9  0000              add [bx si],al
000000FB  0000              add [bx si],al
000000FD  0000              add [bx si],al
000000FF  0000              add [bx si],al
00000101  0000              add [bx si],al
00000103  0000              add [bx si],al
00000105  0000              add [bx si],al
00000107  0000              add [bx si],al
00000109  0000              add [bx si],al
0000010B  0000              add [bx si],al
0000010D  0000              add [bx si],al
0000010F  0000              add [bx si],al
00000111  0000              add [bx si],al
00000113  0000              add [bx si],al
00000115  0000              add [bx si],al
00000117  0000              add [bx si],al
00000119  0000              add [bx si],al
0000011B  0000              add [bx si],al
0000011D  0000              add [bx si],al
0000011F  0000              add [bx si],al
00000121  0000              add [bx si],al
00000123  0000              add [bx si],al
00000125  0000              add [bx si],al
00000127  0000              add [bx si],al
00000129  0000              add [bx si],al
0000012B  0000              add [bx si],al
0000012D  0000              add [bx si],al
0000012F  0000              add [bx si],al
00000131  0000              add [bx si],al
00000133  0000              add [bx si],al
00000135  0000              add [bx si],al
00000137  0000              add [bx si],al
00000139  0000              add [bx si],al
0000013B  0000              add [bx si],al
0000013D  0000              add [bx si],al
0000013F  0000              add [bx si],al
00000141  0000              add [bx si],al
00000143  0000              add [bx si],al
00000145  0000              add [bx si],al
00000147  0000              add [bx si],al
00000149  0000              add [bx si],al
0000014B  0000              add [bx si],al
0000014D  0000              add [bx si],al
0000014F  0000              add [bx si],al
00000151  0000              add [bx si],al
00000153  0000              add [bx si],al
00000155  0000              add [bx si],al
00000157  0000              add [bx si],al
00000159  0000              add [bx si],al
0000015B  0000              add [bx si],al
0000015D  0000              add [bx si],al
0000015F  0000              add [bx si],al
00000161  0000              add [bx si],al
00000163  0000              add [bx si],al
00000165  0000              add [bx si],al
00000167  0000              add [bx si],al
00000169  0000              add [bx si],al
0000016B  0000              add [bx si],al
0000016D  0000              add [bx si],al
0000016F  0000              add [bx si],al
00000171  0000              add [bx si],al
00000173  0000              add [bx si],al
00000175  0000              add [bx si],al
00000177  0000              add [bx si],al
00000179  0000              add [bx si],al
0000017B  0000              add [bx si],al
0000017D  0000              add [bx si],al
0000017F  0000              add [bx si],al
00000181  0000              add [bx si],al
00000183  0000              add [bx si],al
00000185  0000              add [bx si],al
00000187  0000              add [bx si],al
00000189  0000              add [bx si],al
0000018B  0000              add [bx si],al
0000018D  0000              add [bx si],al
0000018F  0000              add [bx si],al
00000191  0000              add [bx si],al
00000193  0000              add [bx si],al
00000195  0000              add [bx si],al
00000197  0000              add [bx si],al
00000199  0000              add [bx si],al
0000019B  0000              add [bx si],al
0000019D  0000              add [bx si],al
0000019F  0000              add [bx si],al
000001A1  0000              add [bx si],al
000001A3  0000              add [bx si],al
000001A5  0000              add [bx si],al
000001A7  0000              add [bx si],al
000001A9  0000              add [bx si],al
000001AB  0000              add [bx si],al
000001AD  0000              add [bx si],al
000001AF  0000              add [bx si],al
000001B1  0000              add [bx si],al
000001B3  0000              add [bx si],al
000001B5  0000              add [bx si],al
000001B7  0000              add [bx si],al
000001B9  0000              add [bx si],al
000001BB  0000              add [bx si],al
000001BD  0000              add [bx si],al
000001BF  0000              add [bx si],al
000001C1  0000              add [bx si],al
000001C3  0000              add [bx si],al
000001C5  0000              add [bx si],al
000001C7  0000              add [bx si],al
000001C9  0000              add [bx si],al
000001CB  0000              add [bx si],al
000001CD  0000              add [bx si],al
000001CF  0000              add [bx si],al
000001D1  0000              add [bx si],al
000001D3  0000              add [bx si],al
000001D5  0000              add [bx si],al
000001D7  0000              add [bx si],al
000001D9  0000              add [bx si],al
000001DB  0000              add [bx si],al
000001DD  0000              add [bx si],al
000001DF  0000              add [bx si],al
000001E1  0000              add [bx si],al
000001E3  0000              add [bx si],al
000001E5  0000              add [bx si],al
000001E7  0000              add [bx si],al
000001E9  0000              add [bx si],al
000001EB  0000              add [bx si],al
000001ED  0000              add [bx si],al
000001EF  0000              add [bx si],al
000001F1  0000              add [bx si],al
000001F3  0000              add [bx si],al
000001F5  0000              add [bx si],al
000001F7  0000              add [bx si],al
000001F9  0000              add [bx si],al
000001FB  0000              add [bx si],al
000001FD  0055AA            add [di-0x56],dl

如您所見,我必須通過在其開頭和結尾使用標簽來計算每個段的大小。然后我為這些大小設定了一些常量。如果您問自己,為什么我不在代碼的開頭放一個標簽,在代碼的末尾放一個標簽?那么我必須告訴你,你只能將標簽放在段中,并且只能從同一段中訪問它們。因此是常數,計算每個常數的大小。

所以總而言之:

  • 如果您為代碼的開頭提供標簽,則第一個org設定程式偏移量END
  • org無論如何,以下所有指令都將充當偏移量
  • 將你SEGMENT的 s 與BYTEs對齊
  • 并做一些不斷的標簽計算黑客來獲得正確的偏移量

請不要完全相信我的話。這只是許多測驗的結果。如果您有任何疑問,請隨時發表評論。
否則,我希望這對找到這個的人有所幫助。

uj5u.com熱心網友回復:

也許使用org 510org 510 7C00h尋求到那一點?

NASM 的檔案特別提到 NASM 不支持 MASMorg指令允許的那種詭計,這意味著 MASMorg 可用于此目的。NASM 檔案甚至顯示了一個 MASM 示例

; MASM example from the NASM manual
        ORG 0 

        ; some boot sector code 

        ORG 510 
        DW 0xAA55

我不知道這可能如何與多個細分市場互動。OP 報告說這僅適用于同一段org的兩個指令。也許有一種方法可以指定段的來源作為宣告它的一部分?


或者也許是另一種選擇,在您沒有將它們填充到固定大小的情況下,您能否要求 MASM 計算這些早期段的大小?(當大小固定時,事情顯然很簡單:你只需在第一個 512 位元組段之后將第二段設為 512 位元組,因此它將以 1024 結束。)

byte 510 - sizeof _TEXT16 -($-_start) dup (0)或類似的東西也減去前面段的長度?我不知道 MASM 是否允許這樣做。顯然這不起作用,所以也許在前面的兩個部分中定義一個equ或或一些東西。size16 = $-start16

無論哪種方式,都不會考慮段之間的填充,如果有任何對齊它們的開始。


或者,當然,如果您不知道如何讓匯編器為您執行此操作,作為構建程序的一部分,您當然可以將引導簽名單獨附加到匯編器的平面二進制輸出中。

在 Linux shell 中,此命令打開boot.bin,尋找位元組 510,并寫入db 0x55, 0xaa

echo -ne '\x55\xAA' | dd of=boot.bin conv=notrunc bs=2 count=1 seek=$((510/2))

如果您在使用 Windows 時遇到問題,則dd例如http://www.chrysocome.net/downloads/dd-0.6beta3.src.zip因為將查找視為多個塊,而不是位元組。而且我不知道如何在 Windows 上傳輸任意二進制資料;如果你已經安裝了它,或者只是使用匯編程式創建一個 2 位元組檔案。bashzsh$((510/2))seek=255ddpython

dd.exe if=aa55.bin of=boot.bin conv=notrunc bs=2 count=1 seek=255

轉載請註明出處,本文鏈接:https://www.uj5u.com/shujuku/527631.html

標籤:Intel Collective 部件x86masm引导加载程序操作系统开发

上一篇:x64fastcall呼叫堆疊管理

下一篇:如何修復此ExcelLAMBDA公式以生成所有SKU和價格、Unpivot公式型別

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • GPU虛擬機創建時間深度優化

    **?桔妹導讀:**GPU虛擬機實體創建速度慢是公有云面臨的普遍問題,由于通常情況下創建虛擬機屬于低頻操作而未引起業界的重視,實際生產中還是存在對GPU實體創建時間有苛刻要求的業務場景。本文將介紹滴滴云在解決該問題時的思路、方法、并展示最終的優化成果。 從公有云服務商那里購買過虛擬主機的資深用戶,一 ......

    uj5u.com 2020-09-10 06:09:13 more
  • 可編程網卡芯片在滴滴云網路的應用實踐

    **?桔妹導讀:**隨著云規模不斷擴大以及業務層面對延遲、帶寬的要求越來越高,采用DPDK 加速網路報文處理的方式在橫向縱向擴展都出現了局限性。可編程芯片成為業界熱點。本文主要講述了可編程網卡芯片在滴滴云網路中的應用實踐,遇到的問題、帶來的收益以及開源社區貢獻。 #1. 資料中心面臨的問題 隨著滴滴 ......

    uj5u.com 2020-09-10 06:10:21 more
  • 滴滴資料通道服務演進之路

    **?桔妹導讀:**滴滴資料通道引擎承載著全公司的資料同步,為下游實時和離線場景提供了必不可少的源資料。隨著任務量的不斷增加,資料通道的整體架構也隨之發生改變。本文介紹了滴滴資料通道的發展歷程,遇到的問題以及今后的規劃。 #1. 背景 資料,對于任何一家互聯網公司來說都是非常重要的資產,公司的大資料 ......

    uj5u.com 2020-09-10 06:11:05 more
  • 滴滴AI Labs斬獲國際機器翻譯大賽中譯英方向世界第三

    **桔妹導讀:**深耕人工智能領域,致力于探索AI讓出行更美好的滴滴AI Labs再次斬獲國際大獎,這次獲獎的專案是什么呢?一起來看看詳細報道吧! 近日,由國際計算語言學協會ACL(The Association for Computational Linguistics)舉辦的世界最具影響力的機器 ......

    uj5u.com 2020-09-10 06:11:29 more
  • MPP (Massively Parallel Processing)大規模并行處理

    1、什么是mpp? MPP (Massively Parallel Processing),即大規模并行處理,在資料庫非共享集群中,每個節點都有獨立的磁盤存盤系統和記憶體系統,業務資料根據資料庫模型和應用特點劃分到各個節點上,每臺資料節點通過專用網路或者商業通用網路互相連接,彼此協同計算,作為整體提供 ......

    uj5u.com 2020-09-10 06:11:41 more
  • 滴滴資料倉庫指標體系建設實踐

    **桔妹導讀:**指標體系是什么?如何使用OSM模型和AARRR模型搭建指標體系?如何統一流程、規范化、工具化管理指標體系?本文會對建設的方法論結合滴滴資料指標體系建設實踐進行解答分析。 #1. 什么是指標體系 ##1.1 指標體系定義 指標體系是將零散單點的具有相互聯系的指標,系統化的組織起來,通 ......

    uj5u.com 2020-09-10 06:12:52 more
  • 單表千萬行資料庫 LIKE 搜索優化手記

    我們經常在資料庫中使用 LIKE 運算子來完成對資料的模糊搜索,LIKE 運算子用于在 WHERE 子句中搜索列中的指定模式。 如果需要查找客戶表中所有姓氏是“張”的資料,可以使用下面的 SQL 陳述句: SELECT * FROM Customer WHERE Name LIKE '張%' 如果需要 ......

    uj5u.com 2020-09-10 06:13:25 more
  • 滴滴Ceph分布式存盤系統優化之鎖優化

    **桔妹導讀:**Ceph是國際知名的開源分布式存盤系統,在工業界和學術界都有著重要的影響。Ceph的架構和演算法設計發表在國際系統領域頂級會議OSDI、SOSP、SC等上。Ceph社區得到Red Hat、SUSE、Intel等大公司的大力支持。Ceph是國際云計算領域應用最廣泛的開源分布式存盤系統, ......

    uj5u.com 2020-09-10 06:14:51 more
  • es~通過ElasticsearchTemplate進行聚合~嵌套聚合

    之前寫過《es~通過ElasticsearchTemplate進行聚合操作》的文章,這一次主要寫一個嵌套的聚合,例如先對sex集合,再對desc聚合,最后再對age求和,共三層嵌套。 Aggregations的部分特性類似于SQL語言中的group by,avg,sum等函式,Aggregation ......

    uj5u.com 2020-09-10 06:14:59 more
  • 爬蟲日志監控 -- Elastc Stack(ELK)部署

    傻瓜式部署,只需替換IP與用戶 導讀: 現ELK四大組件分別為:Elasticsearch(核心)、logstash(處理)、filebeat(采集)、kibana(可視化) 下載均在https://www.elastic.co/cn/downloads/下tar包,各組件版本最好一致,配合fdm會 ......

    uj5u.com 2020-09-10 06:15:05 more
最新发布
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:33:24 more
  • MySQL中binlog備份腳本分享

    關于MySQL的二進制日志(binlog),我們都知道二進制日志(binlog)非常重要,尤其當你需要point to point災難恢復的時侯,所以我們要對其進行備份。關于二進制日志(binlog)的備份,可以基于flush logs方式先切換binlog,然后拷貝&壓縮到到遠程服務器或本地服務器 ......

    uj5u.com 2023-04-20 08:28:06 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:27:27 more
  • 快取與資料庫雙寫一致性幾種策略分析

    本文將對幾種快取與資料庫保證資料一致性的使用方式進行分析。為保證高并發性能,以下分析場景不考慮執行的原子性及加鎖等強一致性要求的場景,僅追求最終一致性。 ......

    uj5u.com 2023-04-20 08:26:48 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:26:35 more
  • 云時代,MySQL到ClickHouse資料同步產品對比推薦

    ClickHouse 在執行分析查詢時的速度優勢很好的彌補了MySQL的不足,但是對于很多開發者和DBA來說,如何將MySQL穩定、高效、簡單的同步到 ClickHouse 卻很困難。本文對比了 NineData、MaterializeMySQL(ClickHouse自帶)、Bifrost 三款產品... ......

    uj5u.com 2023-04-20 08:26:29 more
  • sql陳述句優化

    問題查找及措施 問題查找 需要找到具體的代碼,對其進行一對一優化,而非一直把關注點放在服務器和sql平臺 降低簡化每個事務中處理的問題,盡量不要讓一個事務拖太長的時間 例如檔案上傳時,應將檔案上傳這一步放在事務外面 微軟建議 4.啟動sql定時執行計劃 怎么啟動sqlserver代理服務-百度經驗 ......

    uj5u.com 2023-04-20 08:25:13 more
  • Redis 報”OutOfDirectMemoryError“(堆外記憶體溢位)

    Redis 報錯“OutOfDirectMemoryError(堆外記憶體溢位) ”問題如下: 一、報錯資訊: 使用 Redis 的業務介面 ,產生 OutOfDirectMemoryError(堆外記憶體溢位),如圖: 格式化后的報錯資訊: { "timestamp": "2023-04-17 22: ......

    uj5u.com 2023-04-20 08:24:54 more
  • day02-2-商鋪查詢快取

    功能02-商鋪查詢快取 3.商鋪詳情快取查詢 3.1什么是快取? 快取就是資料交換的緩沖區(稱作Cache),是存盤資料的臨時地方,一般讀寫性能較高。 快取的作用: 降低后端負載 提高讀寫效率,降低回應時間 快取的成本: 資料一致性成本 代碼維護成本 運維成本 3.2需求說明 如下,當我們點擊商店詳 ......

    uj5u.com 2023-04-20 08:24:03 more
  • day02-短信登錄

    功能實作02 2.功能01-短信登錄 2.1基于Session實作登錄 2.1.1思路分析 2.1.2代碼實作 2.1.2.1發送短信驗證碼 發送短信驗證碼: 發送驗證碼的介面為:http://127.0.0.1:8080/api/user/code?phone=xxxxx<手機號> 請求方式:PO ......

    uj5u.com 2023-04-20 08:23:11 more